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

news/2024/11/20 2:52:01/

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 永久重定向的响应。


http://www.ppmy.cn/news/1548386.html

相关文章

【青牛科技】视频监控器应用

1、简介&#xff1a; 我司安防产品广泛应用在视频监控器上&#xff0c;产品具有性能优良&#xff0c;可 靠性高等特点。 2、图示&#xff1a; 实物图如下&#xff1a; 3、具体应用&#xff1a; 标题&#xff1a;视频监控器应用 简介&#xff1a;视频监控器工作原理是光&#x…

docker--工作目录迁移

前言 安装docker&#xff0c;默认的情况容器的默认存储路径会存储系统盘的 /var/lib/docker 目录下&#xff0c;系统盘一般默认 50G&#xff0c;容器输出的所有的日志&#xff0c;文件&#xff0c;镜像&#xff0c;都会存在这个地方&#xff0c;时间久了就会占满系统盘。 一、…

【Pytorch】torch.nn.functional模块中的非线性激活函数

在使用torch.nn.functional模块时&#xff0c;需要导入包&#xff1a; from torch.nn import functional 以下是常见激活函数的介绍以及对应的代码示例&#xff1a; tanh (双曲正切) 输出范围&#xff1a;(-1, 1) 特点&#xff1a;中心对称&#xff0c;适合处理归一化后的数据…

精通Rust系统教程-过程宏入门

本文介绍Rust过程宏定义、分类及应用示例。假设你已经熟悉Rust及基本概念、如数据类型、迭代和特性&#xff08;traits&#xff09;。 Rust宏简介 宏是Rust编程语言的重要组成部分&#xff0c;当你学习Rust语言时&#xff0c;很快就会遇到它们。Rust宏以最简单的方式让你在编译…

使用WebVTT和Track API增强HTML5视频的可访问性和互动性

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 使用WebVTT和Track API增强HTML5视频的可访问性和互动性 使用WebVTT和Track API增强HTML5视频的可访问性和互动性 使用WebVTT和T…

【redis】—— 初识redis(redis基本特征、应用场景、以及重大版本说明)

序言 本文将引导读者探索Redis的世界&#xff0c;深入了解其发展历程、丰富特性、常见应用场景、使用技巧等&#xff0c;最后会对Redis演进过程中具有里程碑意义的版本进行详细解读。 目录 &#xff08;一&#xff09;初始redis &#xff08;二&#xff09;redis特性 &#…

1Panel 推送 SSL 证书到阿里云、腾讯云

本文首发于 Anyeの小站&#xff0c;点击链接 访问原文体验更佳 前言 都用 CDN 了还在乎那点 1 年证书钱么&#xff1f; 开句玩笑话&#xff0c;按照 Apple 的说法&#xff0c;证书有效期不该超过 45 天。那么证书有效期的缩短意味着要更频繁地更新证书。对于我这样的“裸奔”…

ubuntu连接orangepi-zero-2w桌面的几种方法

ubuntu连接orangepi-zero-2w桌面的几种方法 一 &#xff1a; 串口 wifi Nomachine 1 开发板通过串口连接wifi 扫描wifi nmcli dev wifi连接wifi sudo nmcli dev wifi connect wifi_name password wifi_passwd查看开发板IP ifconfig # 假设开发板IP是 192.168.2.32 使用…