Urls.py中有我们所有的路由映射关系。但是随着网站功能的增多,需要配置的URL也变得多了起来。并且维护这些导入也变得很麻烦。因此介绍一些优化和简洁的方法:
一 使用多个视图前缀:
之前所有的路由关系都是包含在一个urlpatterns里面
urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^index/',views.index), url(r'^show_all/',views.show_all_infor), url(r'^result1/',views.result1), url(r'^result2/',views.result2), url(r'^result3/',views.result3), url(r'^books_inquiry/',views.books_inquery_result), ] 但其实我们可以将urlpatterns进行拼接。就像下面的这样。 urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^index/',views.index), url(r'^show_all/',views.show_all_infor), url(r'^result1/',views.result1), url(r'^result2/',views.result2), url(r'^result3/',views.result3), url(r'^books_inquiry/',views.books_inquery_result), ] urlpatterns+=[url(r'^test/',views.function_test),] 二 调试模式: 说到动态构建 urlpatterns,你可能想利用这一技术,在 Django 的调试模式下修改 URLconf 的行为。 为了做到这一点,只要在运行时检查 DEBUG 配置项的值即可 首先在setting.py中需要将DEBUG设置为TRUE。在urls.py中增加DEBUG的判断 from django.conf import settings if settings.DEBUG: urlpatterns+=[url(r'^debuginfo/',views.debug),] 如果DEBUG值为False.则会提示找不到这个URL 三 使用正则表达式:模式包含了一个尖号(^)和一个美元符号($)。这些都是正则表达式符号,并且有特定的含义: 上箭头要求表达式对字符串的头部进行匹配,美元符号则要求表达式对字符串的尾部进行匹配。
用一个例子说明一下这个概念。 如果我们用尾部不是$的模式’^hello/’,那么任何以/hello/开头的URL将会匹配,例如:/hello/foo 和/hello/bar,而不仅仅是/hello/。类似地,如果我们忽略了尖号(^),即’hello/$’,那么任何以hello/结尾的URL将会匹配,例如:/foo/bar/hello/。如果我们简单使用hello/,即没有^开头和$结尾,那么任何包含hello/的URL将会匹配,如:/foo/hello/bar。因此,我们使用这两个符号以确保只有/hello/匹配,不多也不少。
另外一个重点,正则表达式字符串的开头字母“r”。 它告诉Python这是个原始字符串,不需要处理里面的反斜杠(转义字符)。
下面是一些基本的用法:
. (dot)
任意单一字符
\d
任意一位数字
[A-Z]
A 到 Z中任意一个字符(大写)
[a-z]
a 到 z中任意一个字符(小写)
[A-Za-z]
a 到 z中任意一个字符(不区分大小写)
+
匹配一个或更多 (例如, \d+ 匹配一个或 多个数字字符)
[^/]+
一个或多个不为‘/’的字符
*
零个或一个之前的表达式(例如:\d? 匹配零个或一个数字)
*
匹配0个或更多 (例如, \d* 匹配0个 或更多数字字符)
{1,3}
介于一个和三个(包含)之前的表达式(例如,\d{1,3}匹配一个或两个或三个数字)
继续深入下,我们已经设计了一个带通配符的URL,我们有没有方法将它传递到视图中去呢。答案是有的,使用圆括号把参数在URL模式里标识出来然后传递给视图函数。来看一个例子:
在这个url中,test/后面跟的是4个长度的数字。通过(\d{4})可以将test/后面的这个数字传给视图函数
urlpatterns+=[url(r'^test/(\d{4})',views.function_test),] 在views.py中的视图函数中增加一个参数对应(\d{4})。这里的参数year对应的就是(\d{4}) def function_test(request,year): print year 四 包装视图函数 在这里我们使用一个高级的技巧。加入在views.py中存在大量的视图函数需要对登录的安全进行验证。也就是每个函数都需要首选判断requedst.is_secure() def test1(request): if request.is_secure(): return HttpResponse('is secured') else: return HttpResponse('not secured')def test2(request): if request.is_secure(): return HttpResponse('is secured') else: return HttpResponse('not secured')def test3(request): if request.is_secure(): return HttpResponse('is secured') else: return HttpResponse('not secured') 我们是否可以对这种每个函数都需要些的判断做个简化呢。这就需要用到视图包装。来看下下面的这个函数: def requires_login(view): def new_view(request,*args,**kwargs): if request.is_secure(): return HttpResponse('is secured') return view(request,*args,**kwargs) return new_view 再在urlpatterns配置如下 urlpatterns+=[ url(r'^test1/$',views.requires_login(views.test1)), url(r'^test2/$',views.requires_login(views.test2)), url(r'^test3/$',views.requires_login(views.test3)),] 其实方法已经很明确了,用的就是闭包函数的原理,闭包函数实现了公共部分的代码。其实和装饰器是一个道理。那么视图处理函数就可以简化成如下的形式。 def test1(request): return HttpResponse('not secured')def test2(request): return HttpResponse('not secured')def test3(request): return HttpResponse('not secured')转载于:https://www.cnblogs.com/zhanghongfeng/p/8231766.html
相关资源:Django中URL视图函数的一些高级概念介绍