1.网站的入口--路由和视图

URL是网站Web服务的入口。用户在浏览器输入URL发出请求后,django会根据路由系统,运行对应的视图函数,然后返回信息到浏览器中。

1.1 认识路由

创建项目时,会自动生成urls.文件,文件中定义了项目的路由信息,成为项目的路由解析入口。在自建的应用中可以手动配置独立的urls.py文件。

1.1.1 路由系统的基本配置

urls.py文件

from django.contrib import admin
from django.urls import path
from myapp import views urlpatterns = [
path('index/', views.index, name='index'),
]

先导入对应的视图函数,然后在urlpatterns列表中进行url路由配置

path配置语法

path(路由, 视图函数, 别名)

1.1.2 用“路由包含”简化项目复杂度

思路:为每个应用创建一个urls.py文件,将应用的路由配置分别单独放置。

用户发起请求时,会从根路由寻找每个应用的路由信息,生成完整的路由列表。

路由配置规则:

urlpatterns列表会从上到下进行匹配

  • 匹配成功,会根据视图函数进行跳转

  • 匹配失败,则返回404错误

  • 若定义了子路由,则在跟路由中使用include('应用名.urls') 来加载子路由。如果urls的第一部分被匹配看,则其余部分会在子路由中进行匹配。

  • 路由信息一般以/ 结尾

1.1.3 include使用方法

在 Django 项目中,我们可以通过 URLconf 文件(即 views.py 文件)来定义路由规则。而在这个 URLconf 文件中,我们可以使用 include() 函数来指定自己应该包含的其它 URLconf 模块。

通过include可以设置多级路径,语法:

path('', include('应用名称.urls'))
urlpatterns = [
path('', include('myapp.urls'))
]

然后在对应的应用路由文件和视图函数进行配置

myapp的urls.py

from django.contrib import admin
from django.urls import path
from myapp import views urlpatterns = [
path('myapp/index/', views.index)
]

myapp的views.py

from django.shortcuts import render

# Create your views here.
from django.http import HttpResponse def index(request):
return render(request, 'myapp/index.html')

1.1.3 实战一下

  • 在项目根目录运行
python manage.py startapp myapp1
python manage.py startapp myapp2

创建两个应用,myapp1 myapp2

  • 在项目的路由文件中配置
urlpatterns = [
path('', v.index), # 这里设置了启动的默认页面
path('admin/', admin.site.urls),
path('index/', v1.index, name='index'),
path('', include('myapp.urls')),
path('', include('myapp1.urls')),
path('', include('myapp2.urls'))
]

然后在依次对应用的路由和视图函数进行配置(没有则创建)

  • 在模板中进行html文件编写

  • 启动应用
python manage.py runserver

1.2 路由参数

我们不可能为所有页面都手动配置路由规则,需要引入URL参数进行动态配置。

1.2.1 编写带URL参数的路由

Django动态URL的作用是根据特定的参数动态生成URL。这样,我们可以使用相同的视图函数和模板来处理不同的请求,而不必为每个请求编写单独的视图函数。

这个动态的意思是:根据用户输入的地址信息来显示对应的页面信息。

  • 配置

myappurls.py

urlpatterns = [
path('myapp/index/', views.index),
path('myapp/show/<int:id>/', views.show),
]

myappviews.py 增加show函数

def show(request, id):
return HttpResponse('myapp中的show方法, 参数为id, 值为' + str(id))
  • 启动项目

1.2.2 介绍URL参数

在上面的例子中,路由配置为

path('myapp/show/<int:id>/', views.show),

< > 中的内容就是URL参数,语法:

<参数数据类型 : 参数名称>

URL参数有4种数据类型

参数数据类型 说明
str 任意非空字符串,不包含/ ,默认类型
int 匹配0和正整数
slug 匹配任何ASCII字符,连接符和下划线
uuid 匹配一个UUID格式的字符串,该对象必须包括- ,所有字母必须小写。

1.2.3 [实战] 用re_path() 方法正则匹配复杂路由

与path方法作用一样,多了个可以使用正则表达式的功能。

与path一样,使用时,需要导入模块:

from django.urls import re_path

语法:

(?P<name>pattern)
# name是匹配的字符串名称,pattern是要匹配的模式
# name并不会显示在地址栏中,只有被匹配的字符才会出现在地址栏
# 可以同时有多个表达式,用&连接

一个例子

myapp应用中,配置urls.py 获取4个数字赋值给year

urlpatterns = [
path('myapp2/index/', views.index),
re_path(r'myapp2/list/(?P<year>\d{4})/', views.article_list),
]

myapp应用中,配置views.py

def article_list(request, year):
return HttpResponse("myapp2中的article方法, 参数为year, 指定4位, 值为" + str(year))
  • 启动

输入超过4个或少于4个 都会访问失败

1.2.4 反向解析路由

反向解析路由是指通过给定的URL路径反向得到Django中定义的路由。它的作用是方便在代码中生成URL,而不需要手动拼接URL。

路由正常进行配置

path('myapp/url_reverse', views.url_reverse, name = 'myapp_url_reverse')
  • name后面名称最好为应用名_视图函数名称
  • name相当于配置项的别名。可以在视图函数或是模板的HTML文件中调用它
  • 根据name得到路由配置中的URL地址,这就是 反向解析路由
  • 优点:只要name不变,URL地址可以任意改变

例子

myapp1 中进行配置

urls.py

path('myapp1/url_reverse/', views.url_reverse, name = 'myapp1_url_reverse')

views.py

from django.urls import reverse # 记得导入
def url_reverse(request):
# 进行反向解析
print('反向解析结果:' + reverse('myapp1_url_reverse'))
return render(request, '2/url_reverse.html')

在模板中新建文件 2/url_reverse.html,添加代码

<div>
在HTML中使用url标签进行反向解析
<br>
{% url 'myapp1_url_reverse' %}
</div>

启动!

Django学习笔记:第三章D的路由和视图的更多相关文章

  1. Django学习笔记(三)—— 型号 model

    疯狂暑期学习 Django学习笔记(三)-- 型号 model 參考:<The Django Book> 第5章 1.setting.py 配置 DATABASES = { 'defaul ...

  2. 《DOM Scripting》学习笔记-——第三章 DOM

    <Dom Scripting>学习笔记 第三章 DOM 本章内容: 1.节点的概念. 2.四个DOM方法:getElementById, getElementsByTagName, get ...

  3. The Road to learn React书籍学习笔记(第三章)

    The Road to learn React书籍学习笔记(第三章) 代码详情 声明周期方法 通过之前的学习,可以了解到ES6 类组件中的生命周期方法 constructor() 和 render() ...

  4. [HeadFrist-HTMLCSS学习笔记]第三章构建模块:Web页面建设

    [HeadFrist-HTMLCSS学习笔记]第三章构建模块:Web页面建设 敲黑板!! <q>元素添加短引用,<blockquote>添加长引用 在段落里添加引用就使用< ...

  5. JVM学习笔记-第三章-垃圾收集器与内存分配策略

    JVM学习笔记-第三章-垃圾收集器与内存分配策略 tips:对于3.4之前的章节可见博客:https://blog.csdn.net/sanhewuyang/article/details/95380 ...

  6. Spring学习笔记 - 第三章 - AOP与Spring事务

    原文地址:Spring学习笔记 - 第三章 - AOP与Spring事务 Spring 学习笔记全系列传送门: Spring学习笔记 - 第一章 - IoC(控制反转).IoC容器.Bean的实例化与 ...

  7. Qt 学习笔记 - 第三章 - Qt的三驾马车之一 - 串口编程 + 程序打包成Windows软件

    Qt 学习笔记全系列传送门: Qt 学习笔记 - 第一章 - 快速开始.信号与槽 Qt 学习笔记 - 第二章 - 添加图片.布局.界面切换 [本章]Qt 学习笔记 - 第三章 - Qt的三驾马车之一 ...

  8. Django 学习笔记(三)模板导入

    本章内容是将一个html网页放进模板中,并运行服务器将其展现出来. 平台:windows平台下Liunx子系统 目前的目录: hello ├── manage.py ├── hello │ ├── _ ...

  9. python学习笔记——第三章 串

    第三章 字符串学习 1.字符串不灵活, 它不能被分割符值 >>> format = "hello, %s. %s enough for ya?" >> ...

  10. JavaScript高级编程学习笔记(第三章之一)

    继续记笔记,JavaScript越来越有意思了. 继续... 第三章:JavaScript基础 ECMAScript语法在很大程度上借鉴了C和其它类似于C的语言,比如Java和Perl. 大小写敏感: ...

随机推荐

  1. 省市县树形结构打印-.netCore控制台程序

    using CityJson;using Dapper;using Newtonsoft.Json;{ using (var db = DbHelper.Db()) { //数据格式 //code_p ...

  2. linux发行版中的i386/i686/x86-64/的区别

    在yum上找32位的i386找不到,看到i686以为是64位呢,原来它也是32位啊 i686 只是i386的一个子集,支持的cpu从Pentium 2 (686)开始,之前的型号不支持. 备注: 1. ...

  3. ts中接口

    前言:ts定义接口的任意一个属性 interface IPerson { name: string age: number family?: any[] // Error,因为不是任意类型的子集 [p ...

  4. Linux 内存管理 pt.1

    哈喽大家好,我是咸鱼 今天我们来学习一下 Linux 操作系统核心之一:内存 跟 CPU 一样,内存也是操作系统最核心的功能之一,内存主要用来存储系统和程序的指令.数据.缓存等 关于内存的学习,我会尽 ...

  5. [C++核心编程] 4.3、类和对象-C++对象模型和this指针

    文章目录 4.3 C++对象模型和this指针 4.3.1 成员变量和成员函数分开存储 4.3.2 this指针概念 4.3.3 空指针访问成员函数 4.3.4 const修饰成员函数 4.3 C++ ...

  6. STM32 + RTThread + UGUI

    一.概述 开发板:STM32F103C8T6 显示器:ST7735S RT-Thread:5.0.0 玩过 GUI 的小伙伴都知道,界面的显示是一个个像素点组合起来的,那么直接构建出来炫酷的 GUI ...

  7. 逍遥自在学C语言 | 条件控制的正确使用姿势

    前言 在C语言中,有三种条件判断结构:if语句.if-else语句和switch语句. 一.人物简介 第一位闪亮登场,有请今后会一直教我们C语言的老师 -- 自在. 第二位上场的是和我们一起学习的小白 ...

  8. pikachu靶场学习

    pikachu靶场通关 搭建靶场 1.官网下载https://github.com/zhuifengshaonianhanlu/pikachu 2.把pikachu文件夹放到phpstudy的web服 ...

  9. 代码打包的可视化数据分析图: webpack-bundle-analyzer 的使用

    先看webpack-bundle-analyzer的效果图(官方效果图): 通过使用webpack-bundle-analyzer可以看到项目各模块的大小,可以按需优化 1.先安装 npm insta ...

  10. 2021-01-17:java中,HashMap底层数据结构是什么?

    福哥答案2020-01-07: 1.7 数组+链表重要字段://HashMap的主干数组,可以看到就是一个Entry数组,初始值为空数组{},主干数组的长度一定是2的次幂,至于为什么这么做,后面会有详 ...