1、引子
在day17 做業中,咱們查看主機詳細信息的時候,是經過 在url 中拼接,傳參數。urls 中匹配 path("detail/",views.detail)html
這樣url 變成相似 http://127.0.0.1:8000/detail/?nid=2 今天咱們來學習,相似 http://127.0.0.1:8000/detail-3.html 這樣的URL前端
聽說,之前咱們使用的方式 ,在seo 時候算是動態頁面,後面這種方式算靜態頁面。可能在作搜索優化的時候有好處吧。正則表達式
2、開搞栗子
忽略掉數據庫,先在 views 新建一個用戶字典數據庫
2.1 動態頁面的栗子django
views 代碼:函數
1 info_dic={ 2 1:{"name":"zhangsan","email":"zhangsan@163.com","age":22}, 3 2:{"name":"lisi","email":"lisi@163.com","age":27}, 4 3:{"name":"wangwu","email":"wangwu@163.com","age":29}, 5 4:{"name":"laoliu","email":"laoliu@163.com","age":30}, 6 5:{"name":"chenpi","email":"chenpi@163.com","age":32}, 7 } 8 9 def index(request): 10 return render(request,"index.html",{"info_dic":info_dic}) 11 12 13 def detail(request): 14 nid=request.GET.get("nid") 15 print(nid,type(nid)) 16 info=info_dic.get(int(nid)) 17 print(info) 18 return render(request,"detail.html",{"info":info})
urlspost
前端,index.html,學習
1 <!DOCTYPE html> 2 <html> 3 <head lang="en"> 4 <meta charset="UTF-8"> 5 <title></title> 6 </head> 7 <body> 8 <h1>用戶信息</h1> 9 10 <ul> 11 {% for k,v in info_dic.items %} 12 <li><a target="_blank" href="/detail/?nid={{ k }}">{{ v.name }}</a></li> 13 {% endfor %} 14 15 </ul> 16 17 18 19 </body> 20 </html>
前端,detail優化
1 <!DOCTYPE html> 2 <html> 3 <head lang="en"> 4 <meta charset="UTF-8"> 5 <title></title> 6 </head> 7 <body> 8 <h1>用戶詳細信息</h1> 9 10 <ul> 11 <li>name:{{ info.name }}</li> 12 <li>email:{{ info.email }}</li> 13 <li>age:{{ info.age }}</li> 14 </ul> 15 </body> 16 </html>
結果:ui
2.2 下面用 正則表達式來 搞URL 匹配,靜態頁面,
urls
views ,
直接在函數中傳參數,nid 形式參數。不像以前須要本身到 reques.method 中去取
結果
上面的栗子中,咱們得知參數是經過形參傳遞的,相似定義函數的形參數,
下面再搞一個栗子驗證
參數位置變換後 ,獲取的數值也變了
3、分組傳參
在上面的栗子中,咱們知道若是不分組,那麼參數就是相似函數的位置參數,靠天吃飯,
很顯然,這樣不方便咱們在實際的使用中去調用。那麼使用關鍵字參數呢,在URL 匹配中就須要分組
下面搞栗子,變換nid,uid 位置以後,打印的結果是同樣的。
位置參數能夠在 *arg 中獲取,關鍵字參數能夠在 **kwargs 中獲取
4、總結
路由系統:URL
- 普通url:re_path('^index/',view.index),re_path('^home/',view.Home.as_view())
- 順序傳參:re_path(r'^detail-(\d+)-(\d+).html/',views.detail),這個用*args接收
- 關鍵字傳參:re_path(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html/',views.detail),這個用**kwargs接收,推薦使用這個