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/了

 

开始觉得直接写网址简单,用多了你会发现用死网址的方式很糟糕

 

posted @ 2018-09-17 11:20  Operater  阅读(551)  评论(0编辑  收藏  举报