下面,我们编写一个视图,也就是具体的业务代码。
1.在polls/views.py
文件中,编写代码:
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
2.为了调用该视图,我们还需要编写urlconf,也就是路由配置。在polls目录中新建一个配置文件,名字为urls.py
(不要换成别的名字),在其中输入代码如下:
urlpattern
mysite/urls.py
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进行判断
大概逻辑就是mysite-url->polls应用url->view的function
include的背后是一种即插即用的思想。项目的根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。
app所属的二级路由可以根据自己的需要随意编写,不会和其它的app路由发生冲突。app目录可以放置在任何位置,而不用修改路由。这是软件设计里很常见的一种模式。
建议:除了admin路由外,尽量给每个app设计自己独立的二级路由。
好了,路由设置成功后,启动服务器,然后在浏览器中访问地址http://localhost:8000/polls/
。一切正常的话,你将看到一段文字输出。
一个路由配置模块就是一个urlpatterns列表,列表的每个元素都是一项path,每一项path都是以path()的形式存在。
path()方法可以接收4个参数,其中前2个是必须的:route
和view
,以及2个可选的参数:kwargs
和name
。
route
route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项path开始,按顺序依次匹配列表中的项,直到找到匹配的项,然后执行该条目映射的视图函数或下级路由,其后的条目将不再继续匹配。因此,url路由执行的是短路机制,path的编写顺序非常重要!
例子中对应的route就是空字符串''
需要注意的是,route不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 http://localhost/myapp/
时,它会尝试匹配 myapp/
。处理请求 http://localhost/myapp/?page=3
时,也只会尝试匹配 myapp/
。
view
view指的是处理当前url请求的视图函数。当Django匹配到某个路由条目时,自动将封装的HttpRequest
对象作为第一个参数,被“捕获”的参数以关键字参数的形式,传递给该条目指定的视图view。
例子中对应的view就是views.index
kwargs
任意数量的关键字参数可以作为一个字典传递给目标视图。
本例中没有使用这个参数。
name
对你的URL进行命名,让你能够在Django的任意处,尤其是模板内显式地引用它。这是一个非常强大的功能,相当于给URL取了个全局变量名,不会将url匹配地址写死。
本例子中没有使用这个参数。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
2008-01-04 ISA 2004中发布Exchange RPC server
2008-01-04 Cisco IPsec VPN中的Split tunnel
2008-01-04 一些端口