亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Django正則URL匹配實現流程解析

瀏覽:116日期:2024-09-18 14:59:21

一、引子

在day17 作業中,我們查看主機詳細信息的時候,是通過 在url 中拼接,傳參數。urls 中匹配 path('detail/',views.detail)

Django正則URL匹配實現流程解析

這樣url 變成類似 http://127.0.0.1:8000/detail/?nid=2 今天我們來學習,類似http://127.0.0.1:8000/detail-3.html 這樣的URL

據說,以前我們使用的方式 ,在seo 時候算是動態頁面,后面這種方式算靜態頁面。可能在做搜索優化的時候有好處吧。

二、開搞栗子

忽略掉數據庫,先在 views 新建一個用戶字典

2.1 動態頁面的栗子

views 代碼:

info_dic={ 1:{'name':'zhangsan','email':'[email protected]','age':22}, 2:{'name':'lisi','email':'[email protected]','age':27}, 3:{'name':'wangwu','email':'[email protected]','age':29}, 4:{'name':'laoliu','email':'[email protected]','age':30}, 5:{'name':'chenpi','email':'[email protected]','age':32},}def index(request): return render(request,'index.html',{'info_dic':info_dic})def detail(request): nid=request.GET.get('nid') print(nid,type(nid)) info=info_dic.get(int(nid)) print(info) return render(request,'detail.html',{'info':info})

urls

Django正則URL匹配實現流程解析

前端,index.html,

<!DOCTYPE html><html><head lang='en'> <meta charset='UTF-8'> <title></title></head><body> <h1>用戶信息</h1> <ul> {% for k,v in info_dic.items %} <li><a target='_blank' href='http://www.aoyou183.cn/detail/?nid={{ k }}' rel='external nofollow' >{{ v.name }}</a></li> {% endfor %} </ul></body></html>

前端,detail

<!DOCTYPE html><html><head lang='en'> <meta charset='UTF-8'> <title></title></head><body> <h1>用戶詳細信息</h1> <ul> <li>name:{{ info.name }}</li> <li>email:{{ info.email }}</li> <li>age:{{ info.age }}</li> </ul></body></html>

結果:

Django正則URL匹配實現流程解析

Django正則URL匹配實現流程解析

2.2 下面用 正則表達式來 搞URL 匹配,靜態頁面,

urls

Django正則URL匹配實現流程解析

views ,

直接在函數中傳參數,nid 形式參數。不像之前需要自己到 reques.method 中去取

Django正則URL匹配實現流程解析

結果

Django正則URL匹配實現流程解析

上面的栗子中,我們得知參數是通過形參傳遞的,類似定義函數的形參數,

下面再搞一個栗子驗證

Django正則URL匹配實現流程解析

Django正則URL匹配實現流程解析

Django正則URL匹配實現流程解析

Django正則URL匹配實現流程解析

參數位置變換后 ,獲取的數值也變了

Django正則URL匹配實現流程解析

三、分組傳參

在上面的栗子中,我們知道如果不分組,那么參數就是類似函數的位置參數,靠天吃飯,

很顯然,這樣不方便我們在實際的使用中去調用。那么使用關鍵字參數呢,在URL 匹配中就需要分組

下面搞栗子,變換nid,uid 位置之后,打印的結果是一樣的。

Django正則URL匹配實現流程解析

位置參數可以在 *arg 中獲取,關鍵字參數可以在 **kwargs 中獲取

Django正則URL匹配實現流程解析

四、總結

路由系統: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接收,推薦使用這個

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 久久精品免视看国产明星 | 天天色天天碰 | 久久亚洲国产成人精品性色 | 国产精品二区三区 | 国产成人刺激视频在线观看 | 国产欧美另类久久久精品免费 | 国产乱在线观看视频 | 国产特级毛片aaaaaa毛片 | 成人性一级视频在线观看 | 国产精品久久久天天影视香蕉 | 国产免费人成xvideos视频 | 日韩欧美亚洲综合久久99e | 瑟妃19禁福利视频在线看mp4 | 国产精品真实对白精彩久久 | 麻豆md国产在线观看 | 久久国产美女免费观看精品 | 欧美精品blacked中文字幕 | 男女交性粗大视频播放 | 国产在线精品福利一区二区三区 | 亚洲最大情网站在线观看 | 国产精品黄网站 | 91视频免费观看网站 | 久久亚洲私人国产精品 | 免费a级黄色片 | 真人特级毛片免费视频 | 一本久道久久综合 | 青青草久草在线 | 999热精品这里在线观看 | 欧美日韩免费播放一区二区 | 99久久国语露脸精品对白 | 天天做天天爱天天影视综合 | 国产乱子精品免费视观看片 | 国产日本亚洲欧美 | 欧美三区在线观看 | 激情视频在线观看网站 | 日本特级黄色 | 黄色视片| 午夜影视网站 | 国产精品视频免费播放 | 亚洲精品欧美精品 | 男人粗大一出一进女人下面视频 |