1 URL分发器(路由配置文件)
1.1 顶层分发器
在settings的配置文件中,设置了顶层的urls的分发器
ROOT_URLCONF = 'hello_django.urls'
URL配置(URLconf)就像是 Django 所支撑网站的目录。它的本质是 URL 模式以及要为该 URL 模式调用的视图函数之间的映射表。 你就是以这种方式告诉 Django,对于这个 URL 调用这段代码,对于那个 URL 调用那段代码。URL的加载是从配置文件中开始。
1.2 urlpatterns的两种配置形式:
没有前缀的情况,使用的列表(推荐方式)
url patterns = [
url(r’^hello/$’,views.hello)
]
有前缀的情况,使用patterns方法,过时的方法(Django1.9以前使用)
from django.conf.urls import url, patterns
from hello import views
urlpatterns = patterns('',
(r'^hello/$', views.hello),
)
或者
from django.conf.urls import patterns
urlpatterns = patterns('hello',
(r'^hello/$', 'views.hello'),
)
1.3 URL模式:
urlpatterns = [
url(正则表达式, view函数, 参数, 别名,前缀)
]
参数说明:
正则表达式:一个正则表达式字符串。
view函数: 一个可调用对象,通常为一个视图函数或一个指定视图函数路径的字符串。
参数:可选的要传递给视图函数的默认参数(字典形式)。
别名:一个可选的name参数:接合模板方便管理
前缀:app的名字
1.4 URL分解器,include函数:
1.4.1 分解器
通常一个 URL 分解器对应一个 URL 配置模块,它可以包含多个URL模式,也可以包含多个其他URL分解器。通过这种包含结构设计,实现Django对URL的层级解析。URL 分解器是 Django 实现 app 与项目解耦的关键。通常由 include 方法操作的 URL 配置模块,最终会被解释成为 URL 分解器。
1.4.2 include函数
上节课预留的问题,为什么admin模块引入的时候没有使用include
urlpatterns = [
url(r'^admin/',admin.site.urls)
]
admin模块下面的urls是一个方法,并非是一个模块,不需要include。
1.5 URL常见写法示例,正则表达式
url(r'^test/\d{2}/$', views.test)
url(r'^test/(?P<id>\d{2})/$', views.test)
url(r'^test2/(?P<id>\d{2})/(?P<key>\w+) /$', views.test)