url相当于文件,include相当于目录
url(regex, view, kwargs=None, name=None, prefix= '' )
regex:要匹配的 url。
view:该 url 的处理函数,可以是一个表示函数位置的字符串, 也可以是一个函数的实例。
kwargs: 一个字典,表示传递多余的参数。
name : 为 url 进行命名。主要用于反向查找,实现一对一的映射
prefix : if prefix: view = prefix + ' . ' + view 表示在 view 前加上前缀。基本不用
url(r'^(?P\d+)/$', views.DetailView.as_view(), name='detail',{'foo': 'bar'}), (参数)或(?P <参数名> 参数) {额外参数--字典} 参数名>
include(arg, namespace=None, app_name=None)
arg:接受一个字符串,表示被包含的模块在哪里
namespace : 实例命名空间
app_name : 应用命名空间,同一个应用的实例,应该用一样的名字
url(r'^polls/', include('polls.urls', namespace='author-polls', app_name='polls')),
应用命名空间 :
它表示正在部署的应用的名称。 一个应用的每个实例具有相同的应用命名空间。 例如,可以预见Django 的管理站点的应用命名空间是 'admin'。
实例命名空间 :
它表示应用的一个特定的实例 。 实例的命名空间在你的全部项目中应该是 唯一 的。 但是,一个实例的命名空间可以和应用的命名空间相同。它用于表示一个应用的默认实例。 例如,Django 管理站点实例具有一个默认的实例命名空间 'admin' 。
反查的方法,在模板中:
{% for yearvar in year_list %}
在基于类的视图的方法中:
return HttpResponseRedirect(reverse('news-year-archive', args=(year,)))
带名字的url
url(r'^author-polls/', include('polls.urls', include('polls.urls')),
app_name = 'polls'url(r'^$', views.IndexView.as_view(), name='index'),
反向查找
In the method of a class-based view:
reverse('polls:index', current_app=self.request.resolver_match.namespace)
and in the template:
{% url 'polls:index' %}
还有url嵌套
感觉没啥子用....