Django框架学习笔记(五)URL页面跳转进阶及name属性
zhezhongyun 2024-12-10 22:06 29 浏览
知道Django某一个功能的用途,比单纯地知道怎么用更有用。
今天我们要学习的内容是Django的页面跳转,重点讲的是使用url里的name参数
一、给url设置name属性
1. 我想修改路径名
根据前面做好的web项目,登录页面的url为: http://127.0.0.1:8000/login/;如果我们想把路径名login换成signin,该怎么做呢? 这时候我们就想到了在urls的urlpatterns里直接修改path路径名,
2. 遇到麻烦了
如果views里对应的方法有重定向跳转就麻烦了,因为重定向跳转的redirect方法里已经写了我们改名之前的路径名。如果我们在url里将login改成signin,做了一次改名操作了,那么在views里我们还要再改一次。如果有很多个页面都做了重定向到login页面,我们就需要对每一个函数进行修改操作,太麻烦了!有没有什么办法能让我们做路径修改的时候,只需要改一处就能搞定的呢?
3. 解决方法:利用name属性
实际上Django给我们提供了URL的name属性用来标记url,我们可以在path中给指定路径设置一个name属性,
urlpatterns = [
path('signin/', app01_views.login, name="login"),
]
在views中做重定向时不直接写死路径名,而是通过reverse('属性名')反向查出前面的url,这样修改路径名就很方便了,直接修改path就可以了。
return redirect(reverse('login'))
通常情况下,我们是根据path里的路径名,找到views里的方法,然后渲染页面。而这里的重定向反转操作是根据路径名的name属性,反向找到路径的名称。 这样我们需要修改路径名的时候,views里都不要动的,反正它找的是指定的名称。name属性规定好了之后,url路径名想怎么改就怎么改。
注意:使用反转路径名的方法,需要导入包from django.shortcuts import reverse。
4. 如何使用URL的name属性
当前阶段我们主要用在两处: 在View中使用redirect(reverse("login"));
def index(request):
username = request.GET.get('username')
if username:
return render(request,'index.html')
else:
return redirect(reverse('login'))
在html中使用模板语言{% url 'login' %};
<a href="{% url 'login'%}">登录</a>
5. 调用url的name时传递参数
我们先复习一下url传值的两种常见方法:
(1)直接使用url传值
以传递电影编号movie_id为例,如果想通过url传值。在定义path的时候,使用path("movile_detail/<movie_id>",...),然后在views里定义方法来接收movie_id这个值,就定义成def movie_id(request,movie_id),浏览器中访问的时候可以通过127.0.0.1:8000/movie_detail/8001就能把movie_id作为参数通过url传过去。
(2)使用查询字符串传值
我们还是以传递电影编号为例,如果想通过url传值。在定义path时,使用path("movie_detail/",...),在views里定义方法来接收就写成
def movie_id(request):
movie_id = request.GET.get(movie_id)
在浏览器中访问是,url需要输入127.0.0.1:8000/?movie_id=8001。这样也能完成url的传值。
(3)传递参数
在views中,我们使用redirect重定向到一个新的url如果要传递参数该怎么办呢? 有两种方式:
- 方式一: 使用tuple传参数,args=(''rico', '123')
- 方式二: 使用dict传参数,kwargs={'username': 'rico', 'password': '123'}
url设置如下:
urlpatterns = [
# 登录url
path('login/<username>/<password>',app01_views.login, name='login'),
]
在views里定义login方法准备接收两个参数:
def login(request, username, password):
return HttpResponse("用户名:%s \t 密码:%s" % (username, password))
传递参数时:
def index(request):
username = request.GET.get('username')
if username:
return HttpResponse('=== 这是首页 ===')
else:
return redirect(reverse('login', kwargs={'username': 'rico', 'password': '123'}))
注意:是在reverse方法里添加参数,传的如果是元组则注意前后顺序,如果是字典就不用考虑前后顺序。
如果要在templates中通过模板语言调用url的名称, 模板语言里使用url传递参数可以写成这样:
{% url 'login' username='xiaoyu' password='123' %}
二、多app环境下URL的命名
在多app项目中,如果各自的name属性相同,在重定向访问的时候会出现无法访问指定app下的url的问题。这时候我们就在各自app的urls中添加命名空间
app_name = 'app01'
然后在重定向访问指定url名称的时候,添加命名空间属性即可。
def index(request):
username = request.GET.get('username')
if username:
return render(request, 'app01/index.html')
else:
return redirect(reverse('app01:login'))
注意:项目总体url配置使用include关键字,将多个app配置到总路由中。
urlpatterns = [
path('admin/', admin.site.urls),
path('app01/', include('app01.urls')),
path('app02/',include('app02.urls')),
]
最后
这一节,我们主要介绍了Django中url路由跳转的进阶知识,下一节,我们将介绍Django下html页面中的模板语言DTL,感谢大家的阅读~
- 上一篇:安全人员须知的TOP20漏洞编码安全规范(一)
- 下一篇:常见编码总结
相关推荐
- css实现多行文本的展开收起(css实现一行多列)
-
背景在我们写需求时可能会遇到类似于这样的多行文本展开与收起的场景:那么,如何通过纯css实现这样的效果呢?实现的难点(1)位于多行文本右下角的展开收起按钮。(2)展开和收起两种状态的切换。(3)文本...
- 飞牛nas 中继功能再加强!跟所有穿透说再见吧!
-
本内容来源于@什么值得买APP,观点仅代表作者本人|作者:科技菜菜原本飞牛nas的每周更新在周四,这次五一小长假!就提前更新了,虽然音频直通和离线播放是这次更新的主要内容,但是最让所有人开心的则是一...
- 这13个前端库,帮我在工作中赢得了不少摸鱼时间
-
前言平时开发的过程中,常常会使用到一些第三方库来提高开发效率,我总结了自己工作这么久以来经常用到的13个库,希望对大家有帮助~antd全称应该是AntDesign,这是一个React的组件库...
- 前端开发总踩坑?7 个 TypeScript 救命技巧速来查收!
-
在当下的前端开发浪潮中,React、Vue持续霸榜,Webpack性能优化话题不断,而TypeScript凭借强类型特性,成为众多开发者提升代码质量的“秘密武器”。可实际开发时,不少人被类型推导混乱...
- 不花一分钱!提升网站访问速度(让网站访问量提高的最好的方法是什么)
-
原创实用技巧不易,多多转发支持|现在很多公司都通过搭建官方网站的方式,比如电脑报全媒体群就有蛋黄星球(www.cpcw.com)来宣传自己的公司以及相关的产品。但是由于网友所处的位置不同,再加上网络...
- Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-框架)
-
书接上文,以下是VBA用户窗体中常用控件的详细解析,涵盖核心属性、关键事件、典型应用场景及代码示例,助您精准掌握每个控件的使用方法。三、核心控件精讲3.7.框架(Frame)3.7.1、框架控件(Fr...
- Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-高级用法)
-
书接上文,之前是VBA用户窗体中常用控件的详细解析,涵盖核心属性、关键事件、典型应用场景及代码示例,下面是窗体的最后一点我能想到的一些其他漏掉的东西。四、窗体交互进阶技巧4.1非模态窗体frmSea...
- 16.python学习笔记-页面样式(python 页面设计)
-
上一章我们完成了“学习笔记”Web应用程序的大部分功能,本章我们将通过Bootstrap对页面样式进行美化,这样会让我们的项目看起来更加专业。页面样式Bootstrap主页地址:https://get...
- 第8天 | 14天搞定Vue3.0,事件处理(详细)
-
在JavaScript语言中,当用户与UI组件交互时,UI组件能够激发一个相应事件。例如,用户按动按钮、滚动文本、移动鼠标或按下按键等,都将产生一个相应的事件。Vue3.0使用v-on指令(缩写为@符...
- 前端如何实现新手引导功能?(前端新手指引)
-
大家好,我是Echa。在产品发布新版本或者有新功能上线时,经常需要新手引导功能来引导用户了解应用。下面就来分享几个开箱即用的新手引导组件库,帮你快速实现新手引导功能!Intro.jsIntro.js...
- C#_WPF_按钮模板及自定义控件的使用
-
源码私信联系WPF功能强大,但是控件的用法与Winfrom不大一样。这个文件主要说明了Button控件的用法。希望能给大家一个启示。1、按钮加入图片<ButtonGrid.Ro...
- Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-命令按钮)
-
书接上文,以下是VBA用户窗体中常用控件的详细解析,涵盖核心属性、关键事件、典型应用场景及代码示例,助您精准掌握每个控件的使用方法。三、核心控件精讲3.3.命令按钮(CommandButton)3....
- Vue指令:v-bind动态属性绑定(vue动态绑定属性值)
-
1.v-bind:指令认识和基本使用上一小节的学习,让我们理解以v开头的指令后面跟的将是表达式,同样标签也有一些合法的标签属性.如果想将这些属性的值变为表达式,我们可以使用Vue提供的v-bind:...
- C#-初始窗体程序的控件,属性,事件 123
-
新创建的窗体可以说是一个空白的窗体,窗体中什么东西都没有,如果想要把窗体设置成像QQ,酷狗等一样拥有丰富功能和画面的窗体应用界面,则需要手动添加,常用的添加方式有两种即拖控件和编写代码,然后设置其相应...
- Js基础7:表单元素属性(js表格属性)
-
一、封装获取元素的方法封装思想——函数封装——代码复用 function get_id(id){ //这个函数是专门来通过id获...
- 一周热门
- 最近发表
-
- css实现多行文本的展开收起(css实现一行多列)
- 飞牛nas 中继功能再加强!跟所有穿透说再见吧!
- 这13个前端库,帮我在工作中赢得了不少摸鱼时间
- 前端开发总踩坑?7 个 TypeScript 救命技巧速来查收!
- 不花一分钱!提升网站访问速度(让网站访问量提高的最好的方法是什么)
- Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-框架)
- Excel常用技能分享与探讨(5-宏与VBA简介 VBA之用户窗体-高级用法)
- 16.python学习笔记-页面样式(python 页面设计)
- 第8天 | 14天搞定Vue3.0,事件处理(详细)
- 前端如何实现新手引导功能?(前端新手指引)
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- HTML 参考手册 (28)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML常用标签 (29)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- HTML button formtarget 属性 (30)