3django url name详解
打开urls.py
from django.conf.urls import url
from django.contrib import admin
from calc import views as calc_views urlpatterns = [
url(r'^add/$', calc_views.add, name='add'),
url(r'^add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),
url(r'^admin/', admin.site.urls),
]
url(r'^add/$', calc_views.add, name='add'), 这里的 name='add' 是用来干什么的呢?
简单说,name 可以用于在 templates, models, views ……中得到对应的网址,相当于“给网址取了个名字”,只要这个名字不变,网址变了也能通过名字获取到。
为了进一步弄清这个问题,我们先建一个首页的视图和url
2、修改views.py
from django.http import HttpResponse
from django.shortcuts import render def index(request):
return render(request, 'home.html')
render是渲染模板
3、将‘calc’这个app加入到zqxt_views/settings.py中
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles', 'calc',
]
这样,使用render的时候,django会自动找到install_apps中列出的各个app下的templates中的文件
当debug=True的时候,django还可以自动找到各app下static文件夹中的静态文件(js,css,图片等资源),方便开发
4、我们在calc这个app中新建一个templates文件夹,在templates中新建一个home.html文件calc/templates/home.html中写入以下内容
<!DOCTYPE html>
<html>
<head>
<title>自强学堂</title>
</head>
<body> <a href="/add/4/5/">计算 4+5</a> </body>
</html>
修改urls.py
urlpatterns = [
url(r'^$', calc_views.index, name='home'),
url(r'^add/$', calc_views.add, name='add'),
url(r'^add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),
url(r'^admin/', admin.site.urls),
]
运行开发服务器,我们访问 http://127.0.0.1:8000/ 可以看到
我们计算加法的时候用的是/add/4/5/,后来需求发生变化,比如改成/4_add_5/,但在网页中,代码很多地方都写死的/add/4/5/,比如模板中可能是这么写的
<a href="/add/4/5/">计算 4+5</a>
如果这样写‘死网址’,会使得在改了网址(正则)后,模板(template),视图(views.py,比如用于url跳转),模型(models.py,获取记录访问地址等)用了此网址的,都必须进行相应的更改,修改的代价很大,一不小心没改过来,就不能用了
有没有更优雅的方式来解决这个问题呢?当然答案和肯定的
我们先说一下如何用python代码获取对应的网址(可以用在views.py,models.py等各种需要转换得到网址的地方)
我们在终端上输入python manage.py shell
from django.urls import reverse reverse('add2',args=(4,5))
reverse('add2',args=(444,555))
reverse接收url中的name作为第一个参数,我们在代码中就可以通过reverse()来获取对应的网址(这个网址可以用来跳转,也可以用来计算相关页面的地址),只要对应的url的name不改,就不用改代码中的网址
在网页模板中也一样,可以很方便的使用
不带参数的:
{% url 'name' %}
带参数的:参数可以是变量名
{% url 'name' 参数 %} 例如:
<a href="{% url 'add2' 4 5 %}">link</a>
上面的代码渲染成最终的页面是
<a href="/add/4/5/">link</a>
这样就可以通过 {% url 'add2' 4 5 %} 获取到对应的网址 /add/4/5/
当urls.py进行更改,前提是不改name(这个参数设定好后不要轻易改),获取的网址也会动态的跟着变
url(r'^new_add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),
注意看重点add变成了new_add,但是后面的name='add2'没改,这时{% url 'add2' 4 5 %}就会渲染对应的网址成/new_add/4/5/用在views.py或models.py等地方的reverse函数,同样会根据name对应的url获取到新的网址,想要改网址的时候,修改urls.py中的正则表达式部分(url参数第一部分),name不变的前提下,其他地方都不需要修改
另外,比如用户收藏夹中收藏的url是旧的,如何让以前的/add/3/4自动跳转到现在新的网址呢?
django不会帮你做这个,需要自己来写一个跳转方法
具体思路是,在views.py写一个跳转的函数
from django.shortcuts import redirect
from django.urls import reverse def old_add2_redirect(request,a,b):
return redirect(reverse('add2',args=(a,b)))
urls.py中
url(r'^add/(\d+)/(\d+)/$', calc_views.old_add2_redirect),
url(r'^new_add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),
这样,假如用户收藏夹中有/add/4/5/,访问时就会自动跳转到新的/new_add/4/5/了
开始觉得直接写网址简单,用多了你会发现用死网址的方式很糟糕
3django url name详解的更多相关文章
- URL组成部分详解
URL组成部分详解 URL是Uniform Resource Locator的简写,统一资源定位符. 一个URL是由以下几部分组成的: scheme://host:port/path/?query-s ...
- mysql:JDBC url 参数详解
MySql链接url参数详解 jdbc:mysql://[host:port],[host:port].../[database][?参数名1][=参数值1][&参数名2][=参数值2]... ...
- 第五篇Django URL name 详解
Django URL name 详解 利用Django开发网站,可以设计出非常优美的url规则,如果url的匹配规则(包含正则表达式)组织得比较好,view的结构就会比较清晰,比较容易维护. Djan ...
- Flask(4)- URL 组成部分详解
URL Uniform Resource Locator 的简写,中文名叫统一资源定位符 用于表示服务端的各种资源,例如网页 下面将讲解 Flask 中如何提取组成 URL 的各个部分 URL 组 ...
- 输入一个url全过程详解
1. 用户在浏览器中输入url,浏览器接收到url. 2.浏览器接收到这个url之后,会根据这个url会先查看缓存,如果有缓存且没有过期的话直接提供给客户端,完成页面渲染. 3.否则浏览器就会通过DN ...
- Django URL name详解
我们基于上一节的代码来开始这一节的内容. 上节源代码:zqxt_views(django 1.4 - django 1.10).zip [更新于 2016-09-06 00:13:23] 1. 打开 ...
- Django url()函数详解
url()函数看起来的格式象: url(r^/account/$', views.index, name=index) ,它可以接收四个参数,分别是两个必选参数: regex . view 和两个可选 ...
- Node.js中url的详解
var url = require('url');var str = 'http://zhufengnodejs:123@github.com:80/2016jsnode?name=zfpx& ...
- 百度搜索结果页url参数详解
在百度首页输入任意关键词搜索之后,我们跳转到搜索结果页面,在浏览器的网址栏我们可以看到很长的一串url地址.那么,你真的了解这一串url的含义吗? s?:搜索 百度搜索结果页使用了重定向,因此我们看到 ...
随机推荐
- win8硬盘安装Ubuntu14.04双系统參考教程
硬盘安装,无需光盘.U盘.win8为主.Ubuntu14.04为辅.可将Windows或Ubuntu设置为开机默认启动项.在Ubuntu下可查看.操作Windows系统下的文件:适用于安装和14.04 ...
- Nmon命令行:Linux系统性能的监测利器
如果你眼下正在寻找一款非常易于使用的Linux性能监测工具,那么我强烈推荐安装和使用Nmon命令行实用工具. Nmon监测工具 Nmon是一款面向系统管理员的调优和基准测量工具,可以用来显示关于下列方 ...
- A股市场底部顶部历史数据
1. A股市场平均市盈率 大顶沪市平均市盈率:66-70倍. A股市场2次大底沪市平均市盈率:12倍-15倍. 大底时的例子. 2005年6月6日上证指数1000点时的14倍市盈率.2008年10月2 ...
- YUV Player
https://github.com/Yonsm/RawPlayer RawPlayer https://github.com/latelee/YUVPlayer YUVPlayer https:// ...
- HTML_<select>
1.设置select只读不可编辑且select的值可传递 (1) <select onfocus="this.defaultIndex=this.selectedIndex;" ...
- VSCode调试.net core 2.0 输出窗口乱码
Q:输出窗口乱码 A:修改.vscode文件夹下,tasks.json文件,具体内容见图
- org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.jdbc.BadSqlGrammarException: Unknown column 'viewpoint' in 'field list'
问题描述:当我在model中添加了一下代码以后数据库报错: 添加的代码为: private Viewpoint viewpoint; public Viewpoint getViewpoint() { ...
- IntelliJ idea——》创建tag、删除tag
https://blog.csdn.net/weixin_43453386/article/details/83857038
- 多媒体开发之视频格式---1080p逐行和1080i隔行
(1)简介 (2)1080p和1080i的区别 (3) ------------------autho:pkf ----------------------time:2015-1-4 (1)简介 (2 ...
- Android蓝牙通信具体解释
蓝牙通信的大概过程例如以下: 1.首先开启蓝牙 2,搜索可用设备 3,创建蓝牙socket.获取输入输出流 4,读取和写入数据 5.断开连接关闭蓝牙 还要发送配对码发送进行推断! 以下是全部的源码:不 ...