七、Django学习之二级路由详解

from django.contrib import admin
from django.urls import path, re_path
from django.conf.urls import url,include

from my_app.urls import app_name
from . import view
from my_app import views

urlpatterns = [

    path('admin/', admin.site.urls),
    url(r'^admin/', admin.site.urls),
    url(r'^my_app/',include('my_app.urls', namespace='my_app')),
    url(r'^$',view.index),
    path('hello/',view.hello),
    # 添加这一句,my_app/代表跳转到my_app APP中,views.index是关联对应views.py中的一个函数
    url(r'^my_app/',views.index),
    url(r'^my_app/', include(('my_app.urls',app_name), namespace="my_app")),
    path('vote/',include("vote.urls"))
    re_path('^index/$',view.index,name='index'),

]

一、include用法:

其中

urlpatterns = [

    # url(r'^my_app/',include('my_app.urls', namespace='my_app')),
    url(r'^my_app/', include(('my_app.urls',app_name), namespace="my_app")),
    path('vote/',include("vote.urls"))
]

include语法相当于多级路由,它把接收到的url地址去除与此项匹配的部分,将剩下的字符串传递给下一级路由urlconf进行判断

项目根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由可以根据自己的需要随意编写,不会和其它的app路由发生冲突。app目录可以放置在任何位置,而不用修改路由.

二、path用法:

path('admin/', admin.site.urls),
path('vote/',include("vote.urls"))

源码如下:

def _path(route, view, kwargs=None, name=None, Pattern=None):
    if isinstance(view, (list, tuple)):
        # For include(...) processing.
        pattern = Pattern(route, is_endpoint=False)
        urlconf_module, app_name, namespace = view
        return URLResolver(
            pattern,
            urlconf_module,
            kwargs,
            app_name=app_name,
            namespace=namespace,
        )
    elif callable(view):
        pattern = Pattern(route, name=name, is_endpoint=True)
        return URLPattern(pattern, view, kwargs, name)
    else:
        raise TypeError('view must be a callable or a list/tuple in the case of include().')


path = partial(_path, Pattern=RoutePattern)

路由系统中最重要的path()方法可以接收4个参数,其中2个是必须的:routeview,以及2个可选的参数:kwargsname

参数详解:

route:
'''
参数详解:

route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,
按顺序依次匹配列表中的项,直到找到匹配的项,然后执行该条目映射的视图函数或下级路由,其后的条目将不再继续匹配。
因此,url路由的编写顺序非常重要!

着重注意的是,route不会匹配 GET 和 POST 参数或域名。
例如,URLconf 在处理请求 https://127.0.0.1:8000/my_app/时,它会尝试匹配 my_app/。
处理请求 https://127.0.0.1:8000/my_app/?page=3 时,也只会尝试匹配 my_app/。
'''

view:

'''
view指的是处理当前url请求的视图函数。当Django匹配到某个路由条目时,自动将封装的HttpRequest对象作为第一个参数,
被“捕获”的参数以关键字参数的形式,传递给该条目指定的视图view。
'''
kwargs和name
kwargs:

任意数量的关键字参数可以作为一个字典传递给目标视图。

name:

对你的URL进行命名,让你能够在Django的任意处,尤其是模板内显式地引用它。这是一个非常强大的功能,相当于给URL取了个全局变量名,不会将url匹配地址写死

猜你喜欢

转载自www.cnblogs.com/chushujin/p/12421715.html