django-04编写视图

99 阅读3分钟

一、在polls/views.py文件中,编写代码

from django.http import HttpResponse

def index(request):
    return HttpResponse("金克丝的神秘商店")

二、通过polls/urls.py路由配置调用视图 在polls目录中新建一个文件,名字为urls.py(不可变更),输入如下代码:

from django.urls import path

from . import views

urlpatterns = [
    path('', views.index, name='index'),
]

三、在项目的主urls.py文件中进行路由分发
在myproject/urls.py中添加urlpattern条目,指向我们刚才建立的polls这个app独有的urls.py文件,这里需要导入include模块

from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path('polls/', include('polls.urls')),
    path('admin/', admin.site.urls),
]

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

include的背后是一种即插即用的思想。项目的根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由可以根据自己的需要随意编写,不会和其他的app路由发生冲突。app目录可以放在任何位置,而不用修改路由。这是软件设计里很常见的一种模式。

建议:除了admin路由外,尽量给每个app设计自己独立的二级路由。

路由设置成功后,启动服务器python manage.py runserver,然后在浏览器中访问地址http://localhost:8000/polls/。一切正常的话,你将看到金克丝的神秘商店

补充:path()方法

一个路由配置模块就是一个URLpatterns列表,列表的每个元素都是一项path,每一项path都是以path()的形式存在。

path()方法可以接受4个参数,其中前两个参数是必须的:routeview,以及两个可选的参数kwargsname

route

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

例子中对应的route就是空字符串''

需要注意的是,route不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.liujiangblog.com/myapp/时,它会尝试匹配 myapp/。处理请求 https://www.liujiangblog.com/myapp/?page=3 时,也只会尝试匹配 myapp/

view

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

例子中对应的view就是views.index

kwargs

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

本例中没有使用这个参数。

name

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

本例子中没有使用这个参数。