DJango系列的上一篇我们讲到了它是怎么解析和匹配URL的,并从URL中提取一些有用的信息(曾以year和month为例);但是,URL的管理仍然是一个巨大的工程,我们不得不维护数量庞大的pattern,即使有正则表达式的支持。另一方面,URL数量的增大也将带来匹配和解析正确性的考验。这一篇我们会进一步深入URL的学习,并掌握Reverse和Resolve。
一:Reverse和Resolve的作用
我们可以为某一个url映射定义一个名字,称之为url_name,这样有什么用呢?在此之前我们先介绍Reverse和Resolve的含义,函数模板如下:
# 其中viewname表示url_name # 其余的只要理解args即可,表示一些必要的参数,详见例子 # 作用:从url_name得到URL reverse(viewname[, urlconf =
None ,
args = None
, kwargs =
None ,
current_app = None
]) # 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之后的开始的!