django之url---reverse和resolve的用法

DJango的URL的管理是一个巨大的工程,我们不得不维护数量庞大的pattern,即使有正则表达式的支持。另一方面,URL数量的增大也将带来匹配和解析正确性的考验。本篇我们会进一步深入URL的学习,并掌握Reverse和Resolve。

一:Reverse和Resolve的作用
我们可以为某一个url映射定义一个名字,称之为url_name,这样有什么用呢?在此之前我们先介绍Reverse和Resolve的含义,函数模板如下:

1、函数reverse

# 其中viewname表示url_name
# 其余的只要理解args即可,表示一些必要的参数,详见例子
# 作用:从url_name得到URL
reverse(viewname[, urlconf     =     None     , args     =     None     , kwargs     =     None     , current_app     =    None     ])
 2、函数resolve
# path表示url
# 作用: 从url得到相互映射的url_name
resolve(path, urlconf     =     None     )


那什么情况下我们需要用到它们呢?第一,如果在你的Project中需要给出一个网址(如网页重定向等),我们可以通过传递给Reverse函数相应的url_name以及必要的参数,那么便会生成相应的url;第二,在你调试阶段,可以通过Resolve函数来测试你的网站的URL对应关系是否如你所愿。

二:一个简单的例子
修改mysite/urls.py成如下代码:

from     django.conf.urls     import     patterns, include, ur
 
home     =     'hello.views.home'
 
urlpatterns     =     patterns('',
         url(r     '^test$'     , home, name     =     "test_hello"     ),
         url(r     '(\d{4})/(\d{2})$'     , home, name     =     "test_hello_2"     ),
)
在网站根目录下运行:python manage.py shell进入DJango提供的shell环境.然后依次输入如下命令,你可以好好理解一下它们的输出结果:

#这一段曾经有错误,感谢xd(见评论区)同学的指正,万分感谢
from     django.core.urlresolvers     import     reslove, reverse
url     =     resolve(     '/2012/10'     )
print     url.url_name               
#输出应为test_hello_2
 
reverse(     'test_hello_2'     ,args     =     (     '2012'     ,     '10'     ))
#输出应为/2012/10
三:URL Include的目的
当一个Project的模块增多,只在根目录下维护一个urls.py来管理全局的URL对应关系显然是不合适的。如果每个模块都能管理和自己相关的URL,而根目录下的urls.py只负责把它们全部包含进来,不就解决问题了么?这有点像是C/C++里头文件的概念。URL Include的模板如下:

# regex 是正则式
# URL_FILE_NAME 是子模块的urls.py
url(regex, include(     'URL_FILE_NAME'     ))
四:Include的例子
在hello文件下新建urls.py如下:

from     django.conf.urls     import     patterns, include, url
 
home     =     'home'
 
urlpatterns     =     patterns('',
         url(r     '^$'     , home),
)
然后修改mysite/urls.py,增加如下一行即可:

url(r     '^'     , include(     'hello.urls'     )),
现在通过python manage.py runserver启动服务器,在网址输入localhost:8000是不是显示正常呢?如果正常则说明我们include成功了。

不知道你注意到了没有,在mysite/urls.py的正则表达式里面是没有$的。原来在include的用法里,要匹配子模块的urls时是要先通过父模块的匹配,举个例子,如果mysite/urls.py中的匹配为:’^t’,那么传递进include中时是从t之后的开始的
 

猜你喜欢

转载自blog.csdn.net/wangkaibing/article/details/86477208