33. Django 2.1.7 模板 - 动态URL 反向解析

2024-08-21 03:38

本文主要是介绍33. Django 2.1.7 模板 - 动态URL 反向解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文献

  • https://docs.djangoproject.com/zh-hans/2.1/topics/templates/

  • 去除模板中的硬编码 URL[1]

  • 为 URL 名称添加命名空间

反向解析

在前面的篇章中,设置视图view的url是写死一个路径path的,当url的path发生需要改变的时候,就会需要去重写很多地方。

下面先来示例看看写死path的情况。

  1. 打开assetinfo/views.py文件,创建视图fan1、fan2。

def fan1(request):return render(request,'assetinfo/fan1.html')def fan2(request):return HttpResponse('fan2')

2)打开assetinfo/urls.py文件,配置url。

urlpatterns = [# ex:/assetinfo/fan1/path('fan1/', views.fan1),# ex:/assetinfo/fan2/path('fan2/', views.fan2),
]

3)在templates/assetinfo/目录下创建fan1.html。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>普通链接:<a href="/assetinfo/fan2/">fan2</a>
</body>
</html>

4)运行服务器,在浏览器中输入如下网址:http://127.0.0.1:8000/assetinfo/fan1/

5)点击链接后转向fan2,效果如下图:

6)打开assetinfo/urls.py文件,修改"fan2"的正则表达式为"fan_show"。

urlpatterns = [# ex:/assetinfo/fan2/path('fan_show/', views.fan2),
]

7)打开浏览器,后退一下,刷新后再次点击链接,浏览如下图:

问题就来了:随着功能的增加会出现更多的视图,可能之前配置的url路径不够准确,于是就要修改url路径,但是url路径一旦修改了,之前所有对应的超链接都要修改,真是一件麻烦的事情,而且可能还会漏掉一些超链接忘记修改,有办法让链接根据正则表达式动态生成吗?答:反向解析。

反向解析应用在两个地方:模板中的超链接,视图中的重定向。

反向解析

要实现反向解析功能,需要如下步骤:

1)在 assetinfo/urls.py 文件中稍作修改,加上 app_name 设置命名空间namespace:

app_name = 'assetinfo'

2)在assetinfo/urls.py中为url定义name属性,并修改为fan2。

urlpatterns = [path('fan_show/', views.fan2, name='fan2'),
]

3)在模板中使用url标签做超链接,此处为templates/assetinfo/fan1.html文件。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>普通链接:<a href="/assetinfo/fan2/">fan2</a><hr>反向解析:<a href="{% url 'assetinfo:fan2' %}">fan2</a>
</body>
</html>

4)回到浏览器中,后退,刷新,查看源文件如下图,两个链接地址是不一样的。

7)反向解析也可以应用在视图的重定向中。创建一个新的视图fan3,用于重定向fan2,如下:

from django.shortcuts import redirectdef fan3(request):return redirect('assetinfo:fan2')

URL的参数

有些url配置项正则表达式中是有参数的,接下来讲解如何传递参数。

情况一:路径参数

1)在assetinfo/views.py中,创建fan4视图如下:

def fan4(request, a, b):return HttpResponse(a+b)

2)在assetinfo/urls.py中,设置url如下:

app_name = 'assetinfo' # 设置命名空间urlpatterns = [# ex:/assetinfo/fan4/path('fan4/<int:a>/<int:b>', views.fan4, name='fan4'),
]

3)修改templates/assetinfo/fan1.html文件如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>普通链接:<a href="/assetinfo/fan2/">fan2</a><hr>反向解析:<a href="{% url 'assetinfo:fan2' %}">fan2</a><hr>路径参数:<a href="{% url 'assetinfo:fan4' a=2 b=3 %}">fan4</a>
</body>
</html>

4)回到浏览器中,刷新,查看源文件如下图:

点击fan4超链接,如下:

5)使用重定向传递路径参数格式,创建一个fan5的视图,如下:

def fan5(request):a = '1'b = '2'return redirect('assetinfo:fan4',a,b)

或者

def fan5(request):return redirect('assetinfo:fan4',a=1,b=2)

情况二:传递get的问号参数

1) 在assetinfo/views.py中,创建fan6视图,用于接收GET请求参数如下:

def fan6(request):a = int(request.GET.get('a'))b = int(request.GET.get('b'))return HttpResponse(a+b)

2) 在assetinfo/urls.py中,创建fan6的url如下:

urlpatterns = [# ex:/assetinfo/fan6path('fan6', views.fan6, name='fan6'),
]

3)  在浏览器访问fan6测试如下功能,如下:http://127.0.0.1:8000/assetinfo/fan6?a=1&b=2

4) 修改fan1.html,设置超链接访问fan6的请求,如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>普通链接:<a href="/assetinfo/fan2/">fan2</a><hr>反向解析:<a href="{% url 'assetinfo:fan2' %}">fan2</a><hr>路径参数:<a href="{% url 'assetinfo:fan4' a=2 b=3 %}">fan4</a><hr>GET请求问号参数: <a href="{% url 'assetinfo:fan6' %}?a=2&b=3">fan6</a>
</body>
</html>

这里url是动态生成的,但是参数是通过拼接的方式。

5) 访问fan1.html,如下:

点击访问如下:

参考资料

[1]

永久链接至标题: https://docs.djangoproject.com/zh-hans/2.1/intro/tutorial03/#removing-hardcoded-urls-in-templates

这篇关于33. Django 2.1.7 模板 - 动态URL 反向解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092013

相关文章

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

go动态限制并发数量的实现示例

《go动态限制并发数量的实现示例》本文主要介绍了Go并发控制方法,通过带缓冲通道和第三方库实现并发数量限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录带有缓冲大小的通道使用第三方库其他控制并发的方法因为go从语言层面支持并发,所以面试百分百会问到

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

spring中的@MapperScan注解属性解析

《spring中的@MapperScan注解属性解析》@MapperScan是Spring集成MyBatis时自动扫描Mapper接口的注解,简化配置并支持多数据源,通过属性控制扫描路径和过滤条件,利... 目录一、核心功能与作用二、注解属性解析三、底层实现原理四、使用场景与最佳实践五、注意事项与常见问题六