Django URL name详解

我们基于上一节的代码来开始这一节的内容。

上节源代码:zqxt_views(django 1.4 - django 1.10).zip [更新于 2016-09-06 00:13:23]

1. 打开 zqxt_views/urls.py


1

2

3

4

5

6

7

8

9

10

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‘ 是用来干什么的呢?

为了弄清这个问题,我们先建一个首页的视图和url

2. 修改 calc/views.py


1

2

3

4

5

6

7

8

9

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 中


1

2

3

4

5

6

7

8

9

10

INSTALLED_APPS = [

    ‘django.contrib.admin‘,

    ‘django.contrib.auth‘,

    ‘django.contrib.contenttypes‘,

    ‘django.contrib.sessions‘,

    ‘django.contrib.messages‘,

    ‘django.contrib.staticfiles‘,

    ‘calc‘,

]

这样,使用render的时候,Django 会自动找到 INSTALLED_APPS 中列出的各个 app 下的 templates 中的文件。

小提示,DEBUG=True 的时候,Django 还可以自动找到 各 app 下 static 文件夹中的静态文件(js,css,图片等资源),方便开发哦,后面有专门的章节会讲这些。

4. 我们在 calc 这个 app 中新建一个 templates 文件夹,在templates中新建一个 home.html (关于模板更详细的可以稍后看下一节)

文件 calc/templates/home.html 中写入以下内容


1

2

3

4

5

6

7

8

9

10

11

<!DOCTYPE html>

<html>

<head>

    <title>自强学堂</title>

</head>

<body>

<a href="/add/4/5/">计算 4+5</a>

</body>

</html>

修改 zqxt_views/urls.py


1

2

3

4

5

6

7

8

...此处省去一些代码

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/这样的格式,但是我们在网页中,代码中很多地方都写死的是


1

<a href="/add/4/5/">计算 4+5</a>

这样就导致当我们改了 urls.py 后,对应的模板,甚至还视图中的跳转,以及 models.py 中也可能有获取网址的地方。

每个地方都要改,修改的代价很大,一不小心,有的地方没改过来,那个就不能用了


那么有没有更优雅的方式来解决这个问题呢?当然答案是肯定的。

我们先说一下如何用 Python 代码获取对应的网址(可以用在 views.py,models.py等各种需要转换得到网址的地方):

我们在终端上输入(推荐安装 bpython, 这样Django会用 bpython的 shell)


1

python manage.py shell


1

2

3

4

5

>>> from django.core.urlresolvers import reverse

>>> reverse(‘add2‘, args=(4,5))

u‘/add/4/5/‘

>>> reverse(‘add2‘, args=(444,555))

u‘/add/444/555/‘

reverse 接收 url 中的 name 作为第一个参数,我们在代码中就可以通过 reverse() 来获取对应的网址(这个网址可以用来跳转,也可以用来计算相关页面的地址),只要对应的 url 的name不改,就不用改代码中的网址。

在网页模板中也是一样,可以很方便的使用。


1

2

3

4

5

6

7

不带参数的:

{% url ‘name‘ %}

带参数的:参数可以是变量名

{% url ‘name‘ 参数 %}

例如:

<a href="{% url ‘add2‘ 4 5 %}">link</a>

上面的代码渲染成最终的页面是


1

<a href="/add/4/5/">link</a>

这样就可以通过 {% url ‘add2‘ 4 5 %} 获取到对应的网址 /add/4/5/

当 urls.py 进行更改,前提是不改 name(这个参数设定好后不要轻易改),获取的网址也会动态地跟着变,比如改成:


1

url(r‘^new_add/(\d+)/(\d+)/$‘, calc_views.add2, name=‘add2‘),

注意看重点 add 变成了 new_add,但是后面的 name=‘add2‘ 没改,这时 {% url ‘add2‘ 4 5 %} 就会渲染对应的网址成 /new_add/4/5/

reverse 函数也是一样,获取的时候会跟着变成新的网址,这样,在想改网址时只需要改 urls.py 中的正则表达式(url 参数第一部分),其它地方都“自动”跟着变了,是不是这样更好呢?

另外,比如用户收藏夹中收藏的URL是旧的,如何让以前的 /add/3/4/自动跳转到现在新的网址呢?

要知道Django不会帮你做这个,这个需要自己来写一个跳转方法

具体思路是,在 views.py 写一个跳转的函数:


1

2

3

4

5

6

7

8

from django.http import HttpResponseRedirect

from django.core.urlresolvers import reverse

def old_add2_redirect(request, a, b):

    return HttpResponseRedirect(

        reverse(‘add2‘, args=(a, b))

    )

urls.py中:


1

2

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

开始可能觉得直接写网址简单,但是用多了你一定会发现,用“死网址”的方法很糟糕。

时间: 2024-10-22 12:23:41

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

Django url()函数详解

url()函数看起来的格式象:url(r^/account/$', views.index, name=index),它可以接收四个参数,分别是两个必选参数:regex.view和两个可选参数:kwargs.name,接下来详细介绍这四个参数. regex regex代表一个正则表达式,凡是与regex匹配的URL请求都会执行到url()函数中对应的第二个参数view代表的视图函数中.需要注意的是:正则表达式不会匹配URL中的域名和查询参数,如:http://www.foofish.net/ar

Django使用dwebsocket详解(跟着我不翻车)

Django使用websocket详解(最全dwebsocket版) 安装库 pip install dwebsocket 1.test.html 2.settings.py 3.url.py 4.common中的message_websocket.py by xff 原文地址:https://www.cnblogs.com/xufengfan/p/12181130.html

django配置settings详解

项目根目录: 1 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) 项目安全码: 1 SECRET_KEY = ')b)3406p#v$u4ft([email protected]*=0*w1l*=0v0ixdrey)mmcd2uf#(x' DEBUG调试: 1 DEBUG = True 不要在实际生产中打开debug 允许访问的主机: 1 ALLOWED_HOSTS = ['*'] *是代表允许所有主机

谷歌搜索参数url参数详解

谷歌搜索表单参数url参数详解 q(Query):查询的关键词,搜索查询q是必需的URL参数之一,其他都是可选的. 当q的值包含多个单词时,用加号分隔每个单词.(text) hl(Interface Language):Google搜索的界面语言hl=zh-CN简体中文语言界面,我们用的Google中文就是这个参数.hl=zh-TW繁体中文语言界面,港台地区常使用hl=en-英文语言界面 lr(Language Restrict):搜索内容的语言限定限定只搜索某种语言的网页.如果lr参数为空,则

url组成部分详解

url组成部分详解 就以下面这个URL为例,介绍下普通URL的各部分组成 http://www.aspxfans.com:8080/news/index.asp?boardID=5&ID=24618&page=1#name 从上面的URL可以看出,一个完整的URL包括以下几部分: 1.协议部分:该URL的协议部分为"http:",这代表网页使用的是HTTP协议.在Internet中可以使用多种协议,如HTTP,FTP等等本例中使用的是HTTP协议.在"HTTP

MySql JDBC url 参数详解

MySql链接url参数详解 jdbc:mysql://[host:port],[host:port].../[database][?参数名1][=参数值1][&参数名2][=参数值2]... 常用的几个较为重要的参数: 参数名称 参数说明 缺省值 最低版本要求 user 数据库用户名(用于连接数据库)   所有版本 passWord 用户密码(用于连接数据库)   所有版本 useUnicode 是否使用Unicode字符集,如果参数characterEncoding设置为gb2312或gbk

Django框架模板详解

Django模板详解 模板使用 模板基本由两个部分组成,一是HTML代码,二是逻辑控制代码. 逻辑控制的实现又基本由三个部分组成: 1. 变量的使用 {{ person_name }} #使用双大括号来引用变量 2. tag的使用 {% if ordered_warranty %} #使用大括号和百分号的组成来表示使用Django提供的 template tag {% for item in item_list %} <li>{{ item }}</li> {% endfor %}

Django 2.0 新款URL配置详解

Django2.0发布后,很多人都拥抱变化,加入了2的行列.但是和1.11相比,2.0在url的使用方面发生了很大的变化,下面介绍一下: 一.实例 先看一个例子: 1 2 3 4 5 6 7 8 9 10 from django.urls import path from . import views urlpatterns = [     path('articles/2003/', views.special_case_2003),     path('articles/<int:year>