Django路由(urls.py)
路由控制着视图函数的调用。即发起的请求所包含的路由就对应着Django会调用该路由所对应的视图函数。所以,综合来看,在Django中的视图+路由才应该是等价于MVC模式中的C。视图函数确实完成了业务逻辑,但是还差了一个步骤,那就是如何调用这个视图函数,这就是路由的作用。通过路由,Django将不同的路由和不同的视图函数对应起来。这样就可以根据请求中的路由来调用相应的视图函数完成业务逻辑的处理。
书写路由
一般而言,我们会在每一个APP下面新建一个urls.py文件用来存放这个APP的所有路由,然后在项目的urls.py中包含每一个APP的路由文件即可。例如:
from django.urls import path
from book.views import index
urlpatterns = [
path('index', index),
]
from django.urls import path, include
urlpatterns = [
path('book/', include('book.urls')),
]
这样设置之后,我们访问的路由就是/book/index。如下所示: 注意,我们这时候访问一个不存在的url地址(例如:http://127.0.0.1:8000/bxsa),在Django的Debug模式下会给出如下的提示: 这时候Django给出的路由是book/,而不是book/index,当我们访问http://127.0.0.1:8000/book/时,才会给出如下提示。 这种方式确实更好的体现了模块化的思想,首页只告诉你主路由是什么,当你访问了主路由之后,如果子路由不正确,才会给你提示子路由。
相对简单的路由书写方式
如果你嫌弃这种方式比较麻烦,那么也可以在项目的urls.py中按照如下的方式书写路由。
path('', include('book.urls')),
这样,将会在主页提示你所有的路由,这种方式更加方便。只不过你可能需要在APP的urls.py文件中书写多层次的路由。例如:
urlpatterns = [
path('book/index', index),
]
这样书写路由之后,再次访问http://127.0.0.1:8000/之后,将会直接提示你目前所有的路由。例如: 我个人偏向于第二种方式书写路由。
其他注意点
-
路由的开始不需要书写"/",因为Django会自动向ROOT_URLCONF添加"/",你如果写了以"/"开头的url,那么Django将会出现以下警告: WARNINGS:
?: (urls.W002) Your URL pattern '/book/index' has a route beginning with a '/'. Remove this slash as it is unnecessary. If this pattern is targeted in an include(), ensure the include() pattern has a trailing '/'.
-
ROOT_URLCONF在项目的settings.py文件中。 -
路由结束时最好没有"/",这样比较符合restful风格。
|