隨著 Django 版本的升級姓赤,內(nèi)部的一些使用方式也發(fā)生了一些變化娃承,現(xiàn)在討論一下關(guān)于路由配置的一些差異化:
首先看一下工程的整體結(jié)構(gòu)(僅標(biāo)注了本文中使用的文件):Django1.x版本中的寫法:
1以躯、工程路由文件 urls.py
from django.contrib import admin
from django.conf.urls import url, include # 導(dǎo)入 url 模塊
# # 導(dǎo)入應(yīng)用視圖
# 可以在這里設(shè)置全局路由蟆盐,也可以單獨(dú)配置
urlpatterns = [
url(r'^ admin/$',admin.site.urls),
url(r'^ djapp/$',include('djApp.urls'), name= 'djApp'),
]
2移必、本地路由文件 djApp/urls.py
#!/usr/bin/env python
# _*_ coding:utf-8 _*_
# 頭部兩行規(guī)范室谚,支持 utf-8
from django.contrib import admin
from django.conf.urls import url, include # 導(dǎo)入 url 模塊
# 從當(dāng)前目錄導(dǎo)入 views 文件
from . import views
urlpatterns = [
#例如: 表示直接匹配路由 http://127.0.0.0:8000/djapp
url(r'^/$', name = 'index'),
# 例如: 表示直接匹配路由 http://127.0.0.0:8000/djapp/detail/3
url(r'^detail/(?P<id>[0-9]+)/$', name = 'detail'),
...
]
3、視圖文件 views.py
from django.shortcuts import render
# Create your views here.
from django.http import *
from .models import * # 導(dǎo)入模型類
def index(request):
books = BookInfo.objects.all()
context = {
'books': books,
}
return render(request, 'djApp/index.html', context=context)
def detail(request,id):
book_detail = BookInfo.objects.get(pk = id)
context = {
'btitle': book_detail.btitle,
'pub_date': book_detail.bpub_date,
'heros': book_detail.heroinfo_set.all()
}
return render(request, 'djApp/detail_test.html', context=context)
4崔泵、模板文件 index.html
使用超鏈接時(shí):
<li>
<a href="{% url 'djApp:detail' book.id %}">書名:{{ book.btitle }}</a>
</li>
在模板文件 index.html
中秒赤,使用的超鏈接方式,是官方比較推薦的一種方式憎瘸,這樣的好處是:適合實(shí)際項(xiàng)目開發(fā)入篮,便于各種路徑維護(hù)的問題(如模塊路徑更換、路由路徑更新會等)
使用方式如圖所示:
基本語法為:
{% url "應(yīng)用空間命名 : 本地路由方法命名" 本地路由方法參數(shù) %}
幌甘,即djApp
是在 路由文件中為當(dāng)前應(yīng)用創(chuàng)建的一個(gè) 空間命名url(r'^ djapp/$',include('djApp.urls'), name= 'djApp')
中的name = "djApp"
潮售;detail
是在 本地路由文件中為def detail(request,id):
方法創(chuàng)建的路由名稱;book.id
則是 def detail(request,id):
方法中需要傳入的 id
參數(shù)
----------------------分割線------------------------
Django2.0版本中路由寫法:
上述內(nèi)容是在Django1.x
版本中锅风,在模板
中使用路由指定的形式進(jìn)行超鏈接訪問的配置酥诽,但是在Django2.0
版本中時(shí),因?yàn)橄到y(tǒng)使用的是from django.urls import path
模塊皱埠,并非from django.conf.urls import url
模塊肮帐,所以需要進(jìn)行一定的配置調(diào)整:
方法一:
手動(dòng)導(dǎo)入from django.conf.urls import url
,完全按照Django1.x
中路由的配置方法進(jìn)行編寫
方法二:
官方文檔:URL dispatcher
使用系統(tǒng)推薦的from django.urls import path
模塊進(jìn)行設(shè)計(jì)边器,這樣就有幾處需要進(jìn)行改動(dòng):主要是針對1训枢、工程路由文件 urls.py
、2忘巧、本地路由文件 djApp/urls.py
恒界,下面來一一介紹:
1、工程路由文件 urls.py
from django.contrib import admin
from django.urls import path,include
# # 導(dǎo)入應(yīng)用視圖
# 可以在這里設(shè)置全局路由砚嘴,也可以單獨(dú)配置
urlpatterns = [
path('admin/', admin.site.urls),
# 例如: http://127.0.0.0:8000/djapp
path('djapp/', include('djApp.urls', namespace='djApp'))
]
2仗处、本地路由文件 djApp/urls.py
from django.urls import path
from . import views
# 也可以在每個(gè)應(yīng)用中單獨(dú)配置 應(yīng)用的本地路由
app_name = 'djApp'
urlpatterns = [
path('',views.index),
path('index/', views.index),
# 例如: http://127.0.0.0:8000/djapp/detail/3
path('detail/<id>/', views.detail, name = 'detail'),
]
通過這樣配置修改眯勾,在index.html
模本文件中就可以正常以當(dāng)前形式進(jìn)行訪問啦,這時(shí)我們會發(fā)現(xiàn)有幾點(diǎn)需要注意的:
1婆誓、路由配置形式:
path('detail/<id>/', views.detail, name = 'detail')
直接拼接路由吃环,而非通過正則進(jìn)行匹配,對于參數(shù)洋幻,使用<參數(shù)>
進(jìn)行表示郁轻,views.detail
表示對應(yīng)的視圖方法,name = "detail"
同樣表示為 視圖方法
定義的名字(在 模板文件中使用)
2文留、路由使用 include 模塊時(shí):
可以通過path("djapp/", include("djApp.urls", namespace="djApp"))
這種形式進(jìn)行配置應(yīng)用的空間命名 namespace="djApp"
好唯,
但是這樣配置需要一個(gè)前提條件:在本地路由中
配置app_name = 'djApp'
參數(shù),與urlpatterns
同級
關(guān)系圖如下:
當(dāng)然燥翅,系統(tǒng)提供的路由配置方法還有很多骑篙,比如re_path
模塊也可以通過正則表達(dá)式進(jìn)行匹配
等,更多詳情請查看官方文檔:URL dispatcher森书,這里我只是記錄整理了我在工程中遇到的一些問題及解決方案靶端,僅供參考,至此填坑結(jié)束凛膏,先去踩下一個(gè)坑啦
附 : 通過 正則表達(dá)式 匹配路由的規(guī)則
http://blog.csdn.net/kuangshp128/article/details/75669700
# 通過正則表達(dá)式匹配:
#
# ^ (上箭頭):要求表 達(dá)式對字符串的頭部進(jìn)行匹配杨名,
# $(美元符號):要求表達(dá)式對字符串的尾部進(jìn)行匹配
#
# . (dot):任意單一字符
# \d :任意一位數(shù)字
# [A‐Z] :A 到 Z中任意一個(gè)字符(大寫)
# [a‐z] :a 到 z中任意一個(gè)字符(小寫)
# [A‐Za‐z]:a 到 z中任意一個(gè)字符(不區(qū)分大小寫)
# + :匹配一個(gè)或更多 (例如, \d+ 匹配一個(gè)或 多個(gè)數(shù)字字符)
# [^/]+ :一個(gè)或多個(gè)不為‘/’的字符
# ? :零個(gè)或一個(gè)之前的表達(dá)式(例如:\d? 匹配零個(gè)或一個(gè)數(shù)字)
# * :匹配0個(gè)或更多 (例如, \d* 匹配0個(gè) 或更多數(shù)字字符)
# {1,3} :介于一個(gè)和三個(gè)(包含)之前的表達(dá)式(例如,\d{1,3}匹配一個(gè)或兩個(gè)或三個(gè)數(shù)字)
# 動(dòng)態(tài)參數(shù)使用方式:
# /(?P< 參數(shù) >)/
# 關(guān)于配置URL正則的規(guī)則
# 1猖毫、主URL開始地方不要加/
# 2台谍、主URL后面地方要加/
# 3、組件(App)的URL前面不要加/
# 4吁断、主URL后面不要加$
# 5趁蕊、組件(App)后面要加$