Django 学习日记 - urls.py - setp4

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\d{2})/$', views.test)

url(r'^test2/(?P\d{2})/(?P\w+) /$', views.test)

Python正则表达式指南

你可能感兴趣的:(Django 学习日记 - urls.py - setp4)