当前位置: 首页 > news >正文

django从入门到实战(一)——路由的编写规则与使用

Django 路由的编写规则与使用

在 Django 中,路由(URLconf)是将 URL 映射到视图函数的机制。它允许我们定义网站的 URL 结构,并将请求分发到相应的处理函数。以下是关于 Django 路由的定义规则及使用的详细介绍。

1. Django 的路由定义规则

Django 使用 URLconf 来管理 URL 路由。URLconf 是一个包含 URL 模式的 Python 模块,通常在 urls.py 文件中定义。每个 URL 模式都与一个视图函数相关联,Django 会根据请求的 URL 来调用相应的视图。

1.1 Django 的路由定义

在 Django 中,路由定义通常在 urls.py 文件中进行。以下是一个简单的示例:

示例

# myapp/urls.py
from django.urls import path
from . import viewsurlpatterns = [path('', views.home, name='home'),  # 首页path('about/', views.about, name='about'),  # 关于页面
]

在这个示例中,我们定义了两个 URL 模式:

  • '':根 URL,指向 home 视图。
  • 'about/':指向 about 视图。

视图示例

# myapp/views.py
from django.shortcuts import renderdef home(request):return render(request, 'home.html')def about(request):return render(request, 'about.html')
1.2 路由变量的设置

Django 允许在 URL 中使用变量,以便在视图中接收动态数据。变量通过尖括号 < > 定义,并可以指定类型。

示例

# myapp/urls.py
from django.urls import path
from . import viewsurlpatterns = [path('post/<int:post_id>/', views.post_detail, name='post_detail'),  # 帖子详情
]

在这个示例中,<int:post_id> 表示一个整数类型的变量 post_id。当用户访问 /post/1/ 时,post_detail 视图将接收到 post_id=1

视图示例

# myapp/views.py
from django.shortcuts import renderdef post_detail(request, post_id):# 根据 post_id 获取帖子内容return render(request, 'post_detail.html', {'post_id': post_id})

post_detail 视图中,我们可以使用 post_id 来查询数据库或执行其他操作。

1.3 Django 正则表达式的路由定义

除了使用 path() 函数外,Django 还支持使用正则表达式来定义更复杂的 URL 模式。这通常通过 re_path() 函数实现。

示例

# myapp/urls.py
from django.urls import re_path
from . import viewsurlpatterns = [re_path(r'^post/(?P<post_id>\d+)/$', views.post_detail, name='post_detail'),  # 帖子详情
]

在这个示例中,(?P<post_id>\d+) 是一个正则表达式,表示 post_id 是一个数字。与之前的示例相同,当用户访问 /post/1/ 时,post_detail 视图将接收到 post_id=1

视图示例

# myapp/views.py
from django.shortcuts import renderdef post_detail(request, post_id):# 根据 post_id 获取帖子内容return render(request, 'post_detail.html', {'post_id': post_id})

2. Django 路由的命名空间与路由命名

在 Django 中,命名空间和路由命名是管理 URL 模式的重要概念。它们帮助我们避免 URL 名称冲突,并使得在模板和视图中引用 URL 变得更加清晰和方便。

1. 命名空间的介绍及使用

命名空间允许我们将 URL 模式分组,以便在项目中有多个应用时避免名称冲突。通过为每个应用的 URLconf 指定一个命名空间,我们可以在引用 URL 时明确指定应用。

使用示例

假设我们有两个应用:blogshop,它们都有一个名为 detail 的视图。

blog/urls.py

from django.urls import path
from . import viewsapp_name = 'blog'  # 设置命名空间urlpatterns = [path('post/<int:post_id>/', views.post_detail, name='detail'),  # 帖子详情
]

shop/urls.py

from django.urls import path
from . import viewsapp_name = 'shop'  # 设置命名空间urlpatterns = [path('product/<int:product_id>/', views.product_detail, name='detail'),  # 产品详情
]

在这个示例中,我们为 blogshop 应用分别设置了命名空间 blogshop。这样,即使两个应用都有 detail 视图,它们的 URL 名称也不会冲突。

在模板中使用命名空间

在模板中引用 URL 时,可以使用命名空间来明确指定应用。例如:

<a href="{% url 'blog:detail' post_id=1 %}">查看博客帖子</a>
<a href="{% url 'shop:detail' product_id=1 %}">查看产品</a>

在这个示例中,{% url 'blog:detail' post_id=1 %} 会生成指向博客帖子详情的 URL,而 shop:detail 则指向产品详情。

2. 路由命名 name

在 Django 中,为每个 URL 模式指定一个名称是一个良好的实践。通过给 URL 模式命名,我们可以在模板和视图中方便地引用这些 URL,而不需要硬编码 URL 字符串。

使用示例

在定义 URL 模式时,可以使用 name 参数为其命名:

# myapp/urls.py
from django.urls import path
from . import viewsurlpatterns = [path('', views.home, name='home'),  # 首页path('about/', views.about, name='about'),  # 关于页面path('post/<int:post_id>/', views.post_detail, name='post_detail'),  # 帖子详情
]

在这个示例中,我们为每个 URL 模式指定了一个名称,例如 homeaboutpost_detail

在视图中使用命名

在视图中,可以使用 reverse() 函数根据名称生成 URL:

# myapp/views.py
from django.shortcuts import render, redirect
from django.urls import reversedef redirect_to_home(request):return redirect(reverse('home'))  # 根据名称重定向到首页
在模板中使用命名

在模板中引用 URL 时,可以使用 {% url %} 标签:

<a href="{% url 'home' %}">首页</a>
<a href="{% url 'about' %}">关于我们</a>
<a href="{% url 'post_detail' post_id=1 %}">查看帖子</a>

通过使用命名,我们可以轻松地在项目中管理和引用 URL,而不必担心 URL 的具体结构变化。

好的,下面是调整后的内容,标题使用小一号格式。

3. Django 路由的使用方式

在 Django 中,路由的使用方式主要包括在模板中使用路由反向解析以及路由的重定向。这些功能使得 URL 管理更加灵活和方便。

1. 在模板中使用路由

在 Django 模板中,可以使用 {% url %} 标签来引用 URL。这种方式不仅提高了代码的可读性,还使得 URL 的管理更加集中化,避免了硬编码 URL 字符串。

使用示例

假设我们有以下 URL 配置:

# myapp/urls.py
from django.urls import path
from . import viewsurlpatterns = [path('', views.home, name='home'),  # 首页path('about/', views.about, name='about'),  # 关于页面path('post/<int:post_id>/', views.post_detail, name='post_detail'),  # 帖子详情
]

在模板中使用 {% url %} 标签:

<!-- templates/base.html -->
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>My Blog</title>
</head>
<body><nav><ul><li><a href="{% url 'home' %}">首页</a></li><li><a href="{% url 'about' %}">关于我们</a></li><li><a href="{% url 'post_detail' post_id=1 %}">查看帖子</a></li></ul></nav>{% block content %}{% endblock %}
</body>
</html>

在这个示例中,{% url 'home' %} 会生成指向首页的 URL,{% url 'post_detail' post_id=1 %} 会生成指向特定帖子的 URL。

2. 反向解析 reverseresolve

Django 提供了 reverse()resolve() 函数来处理 URL 的反向解析和解析。

2.1 reverse()

reverse() 函数用于根据 URL 名称生成 URL 字符串。它通常在视图中使用。

使用示例

# myapp/views.py
from django.shortcuts import render, redirect
from django.urls import reversedef redirect_to_about(request):return redirect(reverse('about'))  # 根据名称重定向到关于页面

在这个示例中,reverse('about') 会返回关于页面的 URL 字符串。

2.2 resolve()

resolve() 函数用于根据请求的 URL 解析出对应的视图函数和参数。它通常在中间件或自定义视图中使用。

使用示例

# myapp/views.py
from django.urls import resolvedef my_view(request):path = request.path  # 获取请求的路径match = resolve(path)  # 解析路径view_name = match.view_name  # 获取视图名称return render(request, 'my_template.html', {'view_name': view_name})

在这个示例中,resolve(path) 会返回一个匹配对象,其中包含了视图名称和参数。

3. 路由的重定向

在 Django 中,可以使用 redirect() 函数进行路由重定向。重定向可以是基于 URL 名称、URL 字符串或 HTTP 状态码。

使用示例

基于 URL 名称的重定向

# myapp/views.py
from django.shortcuts import redirectdef redirect_to_home(request):return redirect('home')  # 重定向到首页

基于 URL 字符串的重定向

# myapp/views.py
def redirect_to_about(request):return redirect('/about/')  # 重定向到关于页面

使用 HTTP 状态码的重定向

# myapp/views.py
def redirect_with_status(request):return redirect('home', permanent=True)  # 永久重定向到首页

在这个示例中,redirect('home', permanent=True) 会返回一个 301 永久重定向的响应。

相关文章:

django从入门到实战(一)——路由的编写规则与使用

Django 路由的编写规则与使用 在 Django 中&#xff0c;路由&#xff08;URLconf&#xff09;是将 URL 映射到视图函数的机制。它允许我们定义网站的 URL 结构&#xff0c;并将请求分发到相应的处理函数。以下是关于 Django 路由的定义规则及使用的详细介绍。 1. Django 的路…...

vue框架开发的前端项目,build和package的区别

在使用 Vue 框架开发前端项目时&#xff0c;build 和 package 是两个常见的操作&#xff0c;它们有不同的目的和作用。下面是它们的区别&#xff1a; 1. Build&#xff08;构建&#xff09; build 是将前端源代码&#xff08;如 Vue 组件、JavaScript 文件、CSS 样式等&#…...

视频智能分析软件LiteAIServer摄像机实时接入分析平台噪声监测算法介绍

在视频监控领域&#xff0c;噪声问题一直是一个令人头疼的难题。无论是低光环境、摄像机传感器的高灵敏度&#xff0c;还是编码压缩过程中的失真&#xff0c;都可能导致视频中出现噪声&#xff0c;从而影响监控画面的清晰度和准确性。这些噪声不仅降低了视频的可读性&#xff0…...

鸿蒙UI开发与部分布局

UI开发 1. 布局概述 1.1 开发流程 1.先确定开发流程 -> 2.分析页面元素构成 ->3.选用合适的布局容器组件 1.3 布局元素组成&#xff1a;盒模型 2.1 布局分类 2.1 线性布局 线性布局是开发中最常用、最基础的布局&#xff0c;通过线性容器Row和Column构建 2.1.1 线性布…...

redis的map底层数据结构 分别什么时候使用哈希表(Hash Table)和压缩列表(ZipList)

在Redis中&#xff0c;Hash数据类型的底层数据结构可以是压缩列表&#xff08;ZipList&#xff09;或者哈希表&#xff08;HashTable&#xff09;。这两种结构的使用取决于特定的条件&#xff1a; 1. **使用ZipList的条件**&#xff1a; - 当Hash中的数据项&#xff08;即f…...

css水平居中+垂直居中

display:“flex”,position: “absolute”,top:“50%”,left:“50%”,transform: ‘translate(-50%, -50%)’...

设计模式之 组合模式

组合模式&#xff08;Composite Pattern&#xff09;是一种结构型设计模式&#xff0c;它通过将对象组合成树形结构来表示“部分-整体”层次。组合模式允许客户端统一处理单个对象和对象集合。换句话说&#xff0c;组合模式让客户端可以像处理单个对象一样处理对象的集合&#…...

LCR 001 两数相除

一.题目&#xff1a; . - 力扣&#xff08;LeetCode&#xff09; 二.原始解法-超时&#xff1a; class Solution: def divide(self, a: int, b: int) -> int: # 1&#xff09;分析&#xff1a; # 除法计算&#xff0c;不能使用除法符号&#xff0c;可以理解为实现除法 # 除法…...

数据库、数据仓库、数据湖、数据中台、湖仓一体的概念和区别

数据库、数据仓库、数据湖、数据中台和湖仓一体是数据管理和分析领域的不同概念&#xff0c;各自有不同的特点和应用场景。以下是它们的主要区别&#xff1a; 1. 数据库&#xff08;Database&#xff09; 定义&#xff1a;结构化的数据存储系统&#xff0c;用于高效地存储、检…...

vue 的生命周期函数

Vue 生命周期函数&#xff08;生命周期钩子&#xff09;是 Vue 实例从创建到销毁过程中&#xff0c;不同阶段所触发的特定函数。理解这些生命周期函数对于开发 Vue 应用至关重要&#xff0c;因为它们让你在不同的生命周期阶段执行代码&#xff0c;比如数据初始化、DOM 渲染完成…...

单片机UART协议相关知识

概念 UART&#xff08;Universal Asynchronous Receiver/Transmitter&#xff0c;通用异步收发传输器&#xff09; 是一种 异步 串行 全双工 通信协议&#xff0c;用于设备一对一进行数据传输&#xff0c;只需要两根线&#xff08;TX&#xff0c;RX&#xff09;。 异步&…...

【操作系统不挂科】<CPU调度(13)>选择题(带答案与解析)

前言 大家好吖&#xff0c;欢迎来到 YY 滴 操作系统不挂科 系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 本博客主要内容&#xff0c;收纳了一部门基本的操作系统题目&#xff0c;供yy应对期中考试复习。大家可以参考 本章为选择题题库&#xff0c;试…...

OpenCV笔记:图像去噪对比

图像去噪对比 1. 均值滤波&#xff08;Mean Filtering&#xff09; 方法&#xff1a;用像素周围的像素平均值替换每个像素值。适用场景&#xff1a;适用于去除随机噪声&#xff0c;如在不强调图像细节的场景中&#xff0c;如果图像细节较多时&#xff0c;可能会导致图像模糊。…...

A-B数对(二分查找)

#include<bits/stdc.h> using namespace std;using ll long long;int main(){ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n,c;cin>>n>>c;int nu[200000];for(int i0;i<n;i){cin>>nu[i]; // 输入数组元素}sort(nu,nun);ll cnt0; // 统计满…...

Vue 的各个生命周期

详解 Vue 的各个生命周期 文章目录 详解 Vue 的各个生命周期Vue 组件的生命周期1.1 创建阶段示例&#xff1a; 1.2 挂载阶段示例&#xff1a; 1.3 更新阶段示例&#xff1a; 1.4 销毁阶段示例&#xff1a; 生命周期总结生命周期钩子对比表参考链接 Vue 组件的生命周期 在 Vue …...

实现简易计算器 网格布局 QT环境 纯代码C++实现

问题&#xff1a;通过代码完成一个10以内加减法计算器。不需要自适应&#xff0c;界面固定360*350。 ""按钮90*140&#xff0c;其它按钮90*70。 参考样式 #define DEFULT_BUTTON_STYLE "\ QPushButton{\color:#000000;\border:1px solid #AAAAAA;\border-radi…...

后端开发详细学习框架与路线

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;后端开发 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; 为帮助你合理安排时间&#xff0c;以下是结合上述学习内容的阶段划分与时间分配建议。时间安排灵活&a…...

2.langchain中的prompt模板 (FewShotPromptTemplate)

本教程将介绍如何使用 LangChain 库中的 PromptTemplate 和 FewShotPromptTemplate 来构建和运行提示&#xff08;prompt&#xff09;&#xff0c;并通过示例数据展示其应用。 安装依赖 首先&#xff0c;确保你已经安装了 langchain 和相关依赖&#xff1a; pip install lan…...

FairGuard游戏加固实机演示

此前&#xff0c;FairGuard对市面上部分游戏遭遇破解的案例进行了详细分析&#xff0c;破解者会采用静态分析与动态调试相结合的手段&#xff0c;逆向分析出代码逻辑并对其进行篡改&#xff0c;实现作弊功能&#xff0c;甚至是对游戏资源文件进行篡改&#xff0c;从而制售外挂。…...

Spark使用过程中的 15 个常见问题、详细解决方案

目录 问题 1&#xff1a;Spark 作业超时问题描述解决方案Python 实现 问题 2&#xff1a;内存溢出问题描述解决方案Python 实现 问题 3&#xff1a;Shuffle 性能问题问题描述解决方案Python 实现 问题 4&#xff1a;Spark 作业调度不均问题描述解决方案Python 实现 问题 5&…...

React 第五十五节 Router 中 useAsyncError的使用详解

前言 useAsyncError 是 React Router v6.4 引入的一个钩子&#xff0c;用于处理异步操作&#xff08;如数据加载&#xff09;中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误&#xff1a;捕获在 loader 或 action 中发生的异步错误替…...

python/java环境配置

环境变量放一起 python&#xff1a; 1.首先下载Python Python下载地址&#xff1a;Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个&#xff0c;然后自定义&#xff0c;全选 可以把前4个选上 3.环境配置 1&#xff09;搜高级系统设置 2…...

Qt Widget类解析与代码注释

#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码&#xff0c;写上注释 当然可以&#xff01;这段代码是 Qt …...

unix/linux,sudo,其发展历程详细时间线、由来、历史背景

sudo 的诞生和演化,本身就是一部 Unix/Linux 系统管理哲学变迁的微缩史。来,让我们拨开时间的迷雾,一同探寻 sudo 那波澜壮阔(也颇为实用主义)的发展历程。 历史背景:su的时代与困境 ( 20 世纪 70 年代 - 80 年代初) 在 sudo 出现之前,Unix 系统管理员和需要特权操作的…...

土地利用/土地覆盖遥感解译与基于CLUE模型未来变化情景预测;从基础到高级,涵盖ArcGIS数据处理、ENVI遥感解译与CLUE模型情景模拟等

&#x1f50d; 土地利用/土地覆盖数据是生态、环境和气象等诸多领域模型的关键输入参数。通过遥感影像解译技术&#xff0c;可以精准获取历史或当前任何一个区域的土地利用/土地覆盖情况。这些数据不仅能够用于评估区域生态环境的变化趋势&#xff0c;还能有效评价重大生态工程…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词

Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵&#xff0c;其中每行&#xff0c;每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid&#xff0c;其中有多少个 3 3 的 “幻方” 子矩阵&am…...

Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)

目录 一、&#x1f44b;&#x1f3fb;前言 二、&#x1f608;sinx波动的基本原理 三、&#x1f608;波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、&#x1f30a;波动优化…...

CSS设置元素的宽度根据其内容自动调整

width: fit-content 是 CSS 中的一个属性值&#xff0c;用于设置元素的宽度根据其内容自动调整&#xff0c;确保宽度刚好容纳内容而不会超出。 效果对比 默认情况&#xff08;width: auto&#xff09;&#xff1a; 块级元素&#xff08;如 <div>&#xff09;会占满父容器…...

Webpack性能优化:构建速度与体积优化策略

一、构建速度优化 1、​​升级Webpack和Node.js​​ ​​优化效果​​&#xff1a;Webpack 4比Webpack 3构建时间降低60%-98%。​​原因​​&#xff1a; V8引擎优化&#xff08;for of替代forEach、Map/Set替代Object&#xff09;。默认使用更快的md4哈希算法。AST直接从Loa…...

宇树科技,改名了!

提到国内具身智能和机器人领域的代表企业&#xff0c;那宇树科技&#xff08;Unitree&#xff09;必须名列其榜。 最近&#xff0c;宇树科技的一项新变动消息在业界引发了不少关注和讨论&#xff0c;即&#xff1a; 宇树向其合作伙伴发布了一封公司名称变更函称&#xff0c;因…...