在前面的例子里面,咱们已经了解,Django里面能够经过在Project同名的那个目录下的urls.py文件里面配置路由,根据用户输入的url,调用不一样的函数或者类的方法。下面看看具体的一些例子。html
单一的路由对应关系。这种方式最直接,前面已经屡次出现, 能够是fbv或者cbv类型的。python
url(r'^login/', views.login) url(r'^home/', views.Home.as_view()),
基于正则表达式的路由关系。具体来讲,也能够分红两种:a. url(r'^detail-(\d+).html', views.detail) , 这里出现了一个分组(\d+),所以须要额外的再传递一个参数给detail这个函数,若是多个分组的话,须要按照顺序传递多个参数到detail函数b. url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail), 这里由于指定了nid和uid,所以传递参数的时候也须要指明具体是传递给谁的。c. 上面两种状况均可以经过万能参数实现 def detail(request, *args,**kwargs)正则表达式
实战模板:
django
url(r'^detail-(\d+)-(\d+).html', views.detail), def func(request, nid, uid): pass def func(request, *args): args = (2,9) def func(request, *args, **kwargs): args = (2,9) #-----------------------------我是分割线------------------------------------ url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail) def func(request, nid, uid): pass def funct(request, **kwargs): kwargs = {'nid': 1, 'uid': 3} def func(request, *args, **kwargs): args = (2,9)
给路由的映射设置名称,这样更方便调用。reverse方法能够经过name倒过来找url的路径app
url.pyide
url(r'^asdfasdfasdf/', views.index, name='i1'), url(r'^yug/(\d+)/(\d+)/', views.index, name='i2'), url(r'^buy/(?P<pid>\d+)/(?P<nid>\d+)/', views.index, name='i3'),
view.py函数
def func(request, *args, **kwargs): from django.urls import reverse url1 = reverse('i1') # asdfasdfasdf/ url2 = reverse('i2', args=(1,2,)) # yug/1/2/ url3 = reverse('i3', kwargs={'pid': 1, "nid": 9}) # buy/1/9/
xxx.html
ui
{% url "i1" %} # asdfasdfasdf/ {% url "i2" 1 2 %} # yug/1/2/ {% url "i3" pid=1 nid=9 %} # buy/1/9/
多级app目录进行分类url
若是存在多个app目录,每一个app目录下面均可能存在同名的函数或者url,那么这种多级的路由方式,能够经过在主url文件中配置include指向各app目录下的子url文件,而后在app各自的目录下,再配置本身的url文件。spa
好比:
urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^cmdb/', include("app01.urls")), url(r'^monitor/', include("app02.urls")), ]
url.py
urlpatterns = [ url(r'^login/', views.login), url(r'^index/', views.index), url(r'^user_info/', views.user_info), url(r'^userdetail-(?P<nid>\d+)/', views.user_detail), url(r'^userdel-(?P<nid>\d+)/', views.user_del), url(r'^useredit-(?P<nid>\d+)/', views.user_edit), url(r'^orm/', views.orm), ]
views.py
def user_info(request): if request.method == "GET": user_list = models.UserInfo.objects.all() group_list = models.UserGroup.objects.all() return render(request, 'user_info.html', {'user_list': user_list, "group_list": group_list}) elif request.method == 'POST': u = request.POST.get('user') p = request.POST.get('pwd') models.UserInfo.objects.create(username=u,password=p) return redirect('/cmdb/user_info/')
url.py
urlpatterns = [ url(r'^login/', views.login), ]
view.py
def login(request): return HttpResponse('APP02,login')
访问不一样app下的效果
Url里面还能够设置默认值,好比说咱们能够定义一个字典
url(r'^index/', views.index, {'name': 'root'}),
在index这个函数里面,咱们就能够直接调用这个默认值
def index(request,name): print(name) return HttpResponse('OK')
最后一个是命名空间,这个和前面的多级App分类恰好是反过来的。
好比,有两个不一样的Url都指向了同一个App
urls.py
/admin/ include('app01.urls',namespace='m1') /crm/ include('app01.urls',namespace='m2')
app01.urls
/index/ name = 'n1'
函数里面生成url的话,须要指定一条明确的路径
reverser('m1:n1')