Django1.x和Django2.0中路由配置區(qū)別

隨著 Django 版本的升級(jí),內(nèi)部的一些使用方式也發(fā)生了一些變化,現(xiàn)在討論一下關(guān)于路由配置的一些差異化:

首先看一下工程的整體結(jié)構(gòu)(僅標(biāo)注了本文中使用的文件):
結(jié)構(gòu).png

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ù)的問題(如模塊路徑更換、路由路徑更新會(huì)等)使用方式如圖所示:

Django1.x中模板和路由的對應(yīng)關(guān)系.png

基本語法為:{% 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í)我們會(huì)發(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同級(jí)
關(guān)系圖如下:

Django2.0中模板和路由的對應(yīng)關(guān)系.png

當(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)行匹配,
    # $(美元符號(hào)):要求表達(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)后面要加$
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • PythonWeb框架要點(diǎn)、Django介紹、工程搭建、配置、靜態(tài)文件與路由 1.Python Web 框架要點(diǎn) ...
    Cestine閱讀 1,917評論 0 6
  • 最終效果 ●http://www.mydomain.cn/api/ --> http://api.mydomain...
    汪菲宇閱讀 1,110評論 2 1
  • Django的來歷:python開發(fā)的! long long long years ago!勞倫斯出版集團(tuán)新聞 網(wǎng)...
    JAguys閱讀 477評論 0 0
  • URL是Web服務(wù)的入口,用戶通過瀏覽器發(fā)送過來的任何請求,都是發(fā)送到一個(gè)指定的URL地址,然后被響應(yīng)。在Djan...
    汪菲宇閱讀 786評論 0 0
  • 關(guān)鍵詞一:學(xué)會(huì)釋放自己 學(xué)會(huì)釋放,始終自然。忠于自己,理解他人生活不易,人生短短幾十年,沿途風(fēng)景各有不同。我們要做...
    Sugar瑤閱讀 140評論 0 1

友情鏈接更多精彩內(nèi)容