首页 > 代码库 > 06 Django URL name详解
06 Django URL name详解
1、打开urls.py
from django.conf.urls import url from django.contrib import admin from Django_App import views urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^index/‘,views.index), url(r‘^$‘,views.index), url(r‘^login‘,views.login), url(r‘^add/$‘,views.add,name=‘add‘), url(r‘^add/(\d+)/(\d+)/$‘, views.add2, name=‘add2‘), ]
url(r‘^add/$‘,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 是渲染模板
使用render的时候,Django 会自动找到 INSTALLED_APPS 中列出的各个 app 下的 templates 中的文件。
小提示,DEBUG=True 的时候,Django 还可以自动找到 各 app 下 static 文件夹中的静态文件(js,css,图片等资源),方便开发
3、在APP的templates中新建一个 home.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <a href="/add/4/5">计算4+5</a> </body> </html>
修改urls.py
from django.conf.urls import url from django.contrib import admin from Django_App import views urlpatterns = [ url(r‘^admin/‘, admin.site.urls), url(r‘^index/‘,views.index), url(r‘^$‘,views.index,name=‘home‘),#修改部分 url(r‘^login‘,views.login), url(r‘^add/$‘,views.add,name=‘add‘), url(r‘^add/(\d+)/(\d+)/$‘, views.add2, name=‘add2‘), ]
运行开发服务器,我们访问 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,用以用于跳转),模型(models.py,可以用用于获取对象对应的地址)用了此网址的,都得进行相应的更改,修改的代价很大,一不小心,有的地方没改过来,就不能用了。
那有什么解决办法呢?
我们先说一下如何用 Python 代码获取对应的网址(可以用在 views.py,models.py等各种需要转换得到网址的地方):
from django.urls import reverse reverse(‘add2‘, args=(4,5)) Out[3]: ‘/add/4/5/‘ reverse(‘add2‘, args=(444,555)) Out[4]: ‘/add/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+)/$‘, 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.http import HttpResponseRedirect from django.urls import reverse def old_add2_redirect(request, a, b): return HttpResponseRedirect( reverse(‘add2‘, args=(a, b))
在urls.py中添加如下两条记录:
url(r‘^add/(\d+)/(\d+)/$‘, views.old_add2_redirect), url(r‘^new_add/(\d+)/(\d+)/$‘,views.add2, name=‘add2‘),
这样,假如用户收藏夹中有 /add/4/5/ ,访问时就会自动跳转到新的 /new_add/4/5/ 了
06 Django URL name详解