一、簡介
# 路由匹配 url(r'test',views.test), url(r'test_add',views.test_add) # r'test'與請求頭的數據進行正則匹配 ''' url方法第一個參數是正則表達式 只要第一個參數正則表達式能夠匹配到內容,那么就會立刻停止往下匹配 直接執行對應的視圖函數 在輸入url的時候默認加斜杠 django內部幫你做到重定向 一次匹配不行 url后面加斜杠再來一次(瀏覽器加/后,再請求) ''' # 取消自動加斜杠 APPEND_SLASH = False # 默認是True,自動加斜杠 urlpatterns = [ url(r'^admin/', admin.site.urls), # 首頁 url(r'^$',views.home), url(r'^test/$',views.test), url(r'^test_add$',views.test_add), # 尾頁(了解) url(r'',views.error) ]
二 無名分組
分組:就是給某一段正則表達式用小括號括起來
url(r'^test/(d+)',views.test) def test(request,xx): print(xx) # xx位置參數就是(d+)匹配到的數字 return HttpResponse('TEST') # 無名分組就是將括號內正則表達式匹配到的內容當作位置參數傳遞給后面的視圖函數(args)
三有名分組
可以給正則表達式起一個別名,d+的別名就是year url(r'^test_add/(?Pd+)',views.test_add) def test_add(request,year): print(year) return HttpResponse('TEST_ADD') # 有名分組就是將括號內正則表達式匹配到的內容當作關鍵字參數傳遞給后面的視圖函數(kwgs)
四 無名和有名不能混用
# 無名有名不可以混用,但同一個分組可以使用N次 url(r'^test/(d+)/(d+)/(d+)', views.test), url(r'^test_add/(?Pd+)/(?P d+)/(?P d+)', views.test_add),
五 反向解析
# 通過一些方法得到一個結果,該結果可以直接訪問對應的url觸發視圖函數 # 先給路由與視圖函數起一個別名,別名不能起沖突(和static令牌的原理一樣) url(r'^func/',views.func,name='ooo') # 反向解析 # 后端反向解析 from django.shortcuts import render, HttpResponse, redirect,reverse reverse('ooo') # 前端反向解析 111
六 無名有名分組向反向解析
# 無名分組反向解析 url(r'^index/(d+)',views.index,name='xxx') # 前端 {% url 'xxx' 123 %} # 后端 reverse('xxx',args=(1,)) ''' 這個數字寫代碼的時候應該放什么 數字一般情況下放的是數據的主鍵值 數據的編輯和刪除 偽代碼(數據的編輯和刪除),前端數據反向解析給url def edit(request,edit_id) reverse('xxx',args=(edit_id)) listuser.html 數據展示頁 {%for user_obj in user_queryset %} 編輯 {%endfor%} 點擊編輯后,user_obj.id,反向解析,傳給url,r'^edit_user/(d+)',數字傳給視圖函數edit. '''
# 有名分組反向解析 url(r'^func/(?Pd+)/',views.func,name='ooo') # 前端 有名分組,寫法1 有名分組,寫法2,簡便寫法 # 后端 # 有名分組反向解析 寫法1 print(reverse('ooo', kwargs={'year': 123})) # 簡便寫法 print(reverse('ooo',args=(111,)))
七 路由分發
django的每一個應用都可以有自己的templates文件夾、urls.py、static文件夾
基于上述特點,django能夠做到分組開發(每個人寫自己的app)
作為組長,只需要將手下書寫的app全部拷貝到一個新的django項目中,
然后在配置文件里,注冊所有的app再利用路由分發的特點將所有的app整合起來。
當一個django項目中的url特別多的時候,總路由url.py代碼非常冗余不好維護,這個時候也可以利用路由來減輕總路由的壓力。
利用路由分發之后,總路由不再干路由與視圖函數的直接對應關系
而是做一個分發處理,識別當前url是屬于那個應用下的,直接分發給對應的應用去處理。
# 總路由 # from app01 import urls as app01_urls # from app02 import urls as app02_urls urlpatterns = [ url(r'^admin/', admin.site.urls), # 路由分發 # url(r'^app01/', include(app01_urls)), # 只要url前綴是app01開頭 全部交給app01處理 # url(r'^app02/', include(app02_urls)), # 終極寫法,推薦使用 url(r'^app01/',include('app01.urls')), url(r'^app02/',include('app02.urls')) # 注意事項:總路由里面的url千萬不能加$結尾 ] # 子路由 from app01 import views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^reg/', views.reg) ]
八 名稱空間(了解)
# 當多個應用出現了相同的別名,研究反向解析會不會自動識別應用前綴 # 總路由 # 終極寫法,推薦使用 url(r'^app01/',include('app01.urls',namespace='app01')), url(r'^app02/',include('app02.urls',namespace='app02')) # 注意事項:總路由里面的url千萬不能加$結尾 ] # 解析的時候 urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^reg/', views.reg,name='reg') ] def reg(request): # print(reverse('reg')) print(reverse('app01:reg')) return HttpResponse('app01 reg') def reg(request): # print(reverse('reg')) print(reverse('app02:reg')) return HttpResponse('app02 reg') # 只要保證名字不沖突,就沒必要使用名稱空間 ''' 一般情況下,有多個app的時候,起別名的時候會加上app的前綴 這樣的話能夠確保多個app之間名字不沖突的問題,解決 反向解析時不會出錯。 '''
九 偽靜態(了解)
靜態網頁
數據是寫死的,萬年不變
偽靜態
將一個動態網頁偽裝成靜態網頁
為什么要偽裝
https://www.cnblogs.com/Dominic-Ji/p/10881214.html
偽裝的目的在于增大本網站的seo查詢力度
并且增加搜索引擎收藏本網站的概率
搜索引擎的本質上就是一個巨大的爬蟲程序
總結:
無論你怎么優化,怎么處理
始終還是干不過RMB玩家
url(r'^reg.html/', views.reg,name='reg')
十 更多詳細參考
https://www.cnblogs.com/xiaoyuanqujing/articles/11642628.html
鏈接:https://www.cnblogs.com/coderxueshan/p/17590610.html
-
路由
+關注
關注
0文章
278瀏覽量
41955 -
Django
+關注
關注
0文章
45瀏覽量
10425
原文標題:深入解析Django路由層:從基礎配置到高效設計的全攻略
文章出處:【微信號:magedu-Linux,微信公眾號:馬哥Linux運維】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論