urlpatterns的写法和patterns函数
urlpatterns在url文件中是一个url映射列表。在1.8以后的django版本中可直接为列表形式或者也可以用patterns函数生成。在1.7及以前的版本中则是由patterns函数生成。系统会自动遍历url文件中的urlpatterns列表然后进行对应的处理函数查找。当url有重复的情况则以找到的第一个为准。
在这里需要说明一点的是urlpatterns列表中的内容不一定要写在一起,这个变量是支持 += 运算的,这样可以分块完成urlpatterns,结构更好辨认。例如:
urlpatterns = patterns('myapp.views', #第一个参数指定视图所在的位置
(r'^hello/$','hello'), #引用视图中的hello函数,注意这里需要使用单引号
(r'^world/$','world'),
(r'^$', 'home'),
)
urlpatterns +=patterns('contact.views', #第二个视图,urlpatterns是个列表,满足可加性
(r'^contact/$','contact'),
)
然后说下patterns函数的使用。在1.8版本以后可以直接用[]而不用这个函数。有一点注意,如果直接使用[] 那么列表中的项需要明确使用url函数,如果使用patterns我们发现其中的每一项都是直接用括号即可,实际上每个括号相当于url函数的用法。其他的patterns和[]并没有大的差别。
Patterns函数第一个参数是一个空字符串或者视图函数的引用。后面的参数为url列表。每个参数间用逗号隔开。
如果第一个参数为空,那么在写url列表引用处理函数时则需要import引入,传入的是函数名
e.g.
from myapp.views import *
urlpatterns = patterns('', #第一个参数指定视图所在的位置
(r'^hello/$',hello), #引用视图中的hello函数,注意这里需要使用单引号
(r'^world/$',world),
(r'^$', home),
)
如果第一个参数字符串指明了视图函数,则url列表具体函数使用字符串形式传入,且不需要import引入。这里注意,在django中这种查找方式很多,都是以settings中设置的BASE_DIR为基准,写相对路径。
e.g.
urlpatterns = patterns('myapp.views', #第一个参数指定视图所在的位置
(r'^hello/$',’hello’), #引用视图中的hello函数,注意这里需要使用单引号
(r'^world/$',’world’),
(r'^$', ‘home’),
)