1.创建了一个应用后,可以在项目目录下的urls.py中填写路由路径,也可以在应用目录下新建urls.py填写路由路径,然后使用include,将应用目录下的urls引用到项目目录下。
新建vote应用,在vote目录下新建urls.py
#vote目录下urls.py
from django.urls import path
from . import views
urlpatterns = [
path('',views.index1,name = "index1")
]#vote目录下views.py
from django.http import HttpResponse
from django.shortcuts import render
# Create your views here.
def index1(request):
return HttpResponse("hello,world,i am django")#项目目录helloword下urls.py
from django.conf.urls import url
from django.urls import path
# from hello import views
from hello import views
from . import view
urlpatterns = [
path("vote/",include("vote.urls")),#引入vote下的urls
]include语法相当于多级路由,它把接收到的url地址去除与此项匹配的部分,将剩下的字符串传递给下一级路由urlconf进行判断
项目根路由不关心具体app的路由策略,只管往指定的二级路由转发,实现了应用解耦。app所属的二级路由可以根据自己的需要随意编写,不会和其它的app路由发生冲突。app目录可以放置在任何位置,而不用修改路由.
在浏览器中访问地址http://localhost:8000/vote/

path方法用法:
路由系统中最重要的path()方法可以接收4个参数,其中2个是必须的:route和view,以及2个可选的参数:kwargs和name。
route:
route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项,然后执行该条目映射的视图函数或下级路由,其后的条目将不再继续匹配。因此,url路由的编写顺序非常重要!
需要注意的是,route不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/时,它会尝试匹配 myapp/。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/。
view:
view指的是处理当前url请求的视图函数。当Django匹配到某个路由条目时,自动将封装的HttpRequest对象作为第一个参数,被“捕获”的参数以关键字参数的形式,传递给该条目指定的视图view。
kwargs:
任意数量的关键字参数可以作为一个字典传递给目标视图。
name:
对你的URL进行命名,让你能够在Django的任意处,尤其是模板内显式地引用它。这是一个非常强大的功能,相当于给URL取了个全局变量名,不会将url匹配地址写死。