有时你有一个模式来处理在你的URLconf中的一系列URL,但是有时候需要特别处理其中的某个URL。 在这种情况下,要使用将URLconf中把特殊情况放在首位的线性处理方式 。
比方说,你可以考虑通过下面这个URLpattern所描述的方式来向Django的管理站点添加一个目标页面
1
2
3
4
5
|
urlpatterns = patterns('', # ... ( '^([^/]+)/([^/]+)/add/$' , views.add_stage), # ... ) |
这将匹配像 /myblog/entries/add/ 和 /auth/groups/add/ 这样的URL 。然而,对于用户对象的添加页面( /auth/user/add/ )是个特殊情况,因为它不会显示所有的表单域,它显示两个密码域等等。 我们 可以 在视图中特别指出以解决这种情况:
1
2
3
4
5
|
def add_stage(request, app_label, model_name): if app_label = = 'auth' and model_name = = 'user' : # do special-case code else : # do normal code |
不过,就如我们多次在这章提到的,这样做并不优雅: 因为它把URL逻辑放在了视图中。 更优雅的解决方法是,我们要利用URLconf从顶向下的解析顺序这个特点:
1
2
3
4
5
6
|
urlpatterns = patterns('', # ... ( '^auth/user/add/$' , views.user_add_stage), ( '^([^/]+)/([^/]+)/add/$' , views.add_stage), # ... ) |
在这种情况下,象 /auth/user/add/ 的请求将会被 user_add_stage 视图处理。 尽管URL也匹配第二种模式,它会先匹配上面的模式。 (这是短路逻辑。)