快活林资源网 Design By www.csstdc.com
在Django 2.0版本之前,在urls,py文件中,用url设定视图函数
urlpatterns = [ url(r'login/',views.login), ]
其中第一个参数是正则匹配,如下代码,输入http://127.0.0.1:8000/login,出现的是login页面,但是输入login2,出现的还是login页面,这是因为Django会将匹配成功的返回,不会继续往下匹配
urlpatterns = [ url(r'login',views.login), url(r'login2',views.login2), ]
所以为了避免上面这种情况,可以在第一个参数加上正则表达式
urlpatterns = [ url(r'^login/$',views.login), url(r'^login2/$',views.login2), ]
^ 号限定开头,$限定结尾,' / '为匹配机制,比如第一次输入:http://127.0.0.1:8000/login,没有匹配成功,系统会自动加上‘/‘再进行一次匹配
这样就可以写出首页和尾页(尾页是指找不到对应页面时打开的页面,俗称404)
urlpatterns = [ url(r'^$',views.home), #这是首页 url(r'',views.error) #这是尾页 ]
同样的既然可以进行正则匹配,那么就可以写更多的正则语法:
urlpatterns = [ url(r'^login/[0-9]{4}$',views.login), ]
类似上面写出的正则,就是login/ 后面随意加上4位数字都可以访问login页面
同样的正则还有分组的概念,但是在Django中把分组分为两种:无名分组和有名分组
无名分组:
urlpatterns = [ url(r'^login/([0-9]{4})$',views.login), ]
在普通的正则匹配中加上()就是无名分组,那么这样有什么意义呢?
首先在后端的views上,会得到一个分组的参数,以上面代码为例,那么views.login函数的参数除了request,还需要添加一个参数(名字随意),进行几次分组那么就需要多添加几次参数
进入view页面,其中xxx的名字是随意的,传进来的分组的数据例如我输入的网址是:login/222,那么xxx的值为222
def login(request,xxx): print(xxx)
有名分组:
有名分组其实就是在无名的分组的基础上加上了名字
快活林资源网 Design By www.csstdc.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
快活林资源网 Design By www.csstdc.com
暂无评论...
更新日志
2024年12月23日
2024年12月23日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]