1.什么是路由層
簡單來說,就是通過路由層中的path函式,告訴django遇到那個url,執行那個視圖函式
2.路由層的請求流程
1.客戶在瀏覽器輸入網址→請求進入django的setting.py中的ROOT_URLCONF尋找指定使用的urls.py檔案位置(如果中間件有路由功能,urls檔案功能會被其替代)
2.Django會先匹配專案目錄下的path路徑然后在匹配應用里面的url路徑,從上至下查找url匹配,一旦匹配成功,停止查找,
3.一旦匹配url成功后,路由層向視圖層傳遞下列引數:
1)一個HttpRequest實體,即request
2)如果url中的可變引數沒有命名,那么就按照位置來與視圖函式中的形參一一對應,如果有則按關鍵字方式傳參
4.如果匹配不到url,Django會發出例外
re_path(r'^test/$',views.test)
注意:path路徑匹配是會自動在url后面加上一個斜杠,即先匹配test沒有找到,會自動加個/在匹配一次!
如何取消自動加斜杠?
在setting.py里添加APPEND_SLASH = False 默認是True
3.路由層的格式和引數說明
3.1有名分組和無名分組
分組:就是給某一段正則運算式用小括號擴起來
無名分組:就是將括號內的正則運算式匹配到的內容當做位置引數傳遞給后面的視圖函式
from django.urls import path, re_path
re_path(r'^test/(\d+)/',views.test)
def test(request,xx): # xx這個引數就是對應path里面的(\d+)
pass
有名分組:可以給正則運算式起個別名
from django.urls import path, re_path
re_path(r‘^(?P<自定義引數名>正則運算式)/$',view.xxx,name),
def test(request,自定義引數名):
pass
有名無名不能混用!單個分組可以使用多次!
3.2url反向決議
反向決議的步驟:
# 1.先給改url起一個別名
re_path(r'^test/$',views.test,name='ooo')
# 2.后端反向決議(視圖層)
先匯入reverse
from django.shortcuts import reverse
print(reverse(‘ooo’)) # 得到的就是對應別名的url
# 3.前端反向決議
在需要url的地方,改成如下格式:
<a href='https://www.cnblogs.com/suncolor/p/{% url'ooo' %}'>111</a>
3.3有名無名的反向決議
1.無名分組
后端部分:
先匯入reverse
from django.shortcuts import reverse
print(reverse(‘ooo’),args=(1,))#需要傳一個對應引數args,里面的1可以配正則運算式匹配到
前端部分:
<a href='https://www.cnblogs.com/suncolor/p/{% url'ooo' 123 %}'>111</a>
# 123是匹配到url的正則運算式
2.有名分組
其實是和無名分組一樣的,但是也可以寫成關鍵字方式傳參
print(reverse(‘ooo’),kwargs={‘year’:1111}))
<a href='https://www.cnblogs.com/suncolor/p/{% url'ooo' year=1111a>
傳入的數字引數一般是資料的主鍵值!!
3.4路由分發
起因:分布式路由是基于django應用誕生的,有了應用則就應該有分布式路由,主路由不用在處理用戶具體路由了,而是轉而做請求的分發,具體的請求由各自的應用負責,
主路由語法:
from django.urls import path,include
# 匹配http://127.0.0.1:8000/music/index--music應用path('music/', include('music.urls'))
include('app名字.url模塊名')
作用是將當前path里面music路由轉到include里面的這個應用路由里處理
子路由語法:
手動創建一個urls.py,結構和主路由完全一樣
只是path后面的第一個引數,只需管主路由path匹配的后面一部分
3.5名稱空間
在各路由起別名的時候,由于我們采用的是分布式路由開發,很有可能每個開發人員起的別名是一樣的,這樣我們在進行反向決議的時候就沒有用了!
因此,名稱空間的使用很好的解決了這一問題!具體的語法如下:
# 總路由
re_path(r'^app01/',include('app01.urls',namespace='app01')),
re_path(r'^app02/',include('app02.urls',namespace='app02'))
# 決議的時候
# app01
urlpatterns = [
url(r'^reg/',views.reg,name='reg')
]
# app02
urlpatterns = [
url(r'^reg/',views.reg,name='reg')
]
# 視圖層:
reverse('app01:reg')
reverse('app02:reg')
# 模板層:
{% url 'app01:reg' %}
{% url 'app02:reg' %}
但其實,我們在起別名的時候只要保證別名不沖突,就沒有必要使用名稱空間,
一般情況下,有多個app的時候我們在起別名的時候會加上app的前綴,如name=‘app01_xxx’,這樣就能解決了!
3.6路由層的轉換器
path('page/<int:num>', views.test),
說明:1.path轉換器:可以用來批量匹配一百個網頁分別為page/1、page/2...等
2.語法為:<轉換器型別:自定義名>
3.作用:若轉換器型別匹配到對應型別的資料,則將資料按照關鍵字傳參的方式傳遞給視圖函式
4.轉換器的型別:str:匹配除了'/'之外的非空字串;int:匹配0或者任何正整數;# slug:匹配任意由ascll字母或數字以及連字符和下劃線組成的短標簽;path:匹配非空欄位,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/505260.html
標籤:Python
