如何高效使用Django中的URL标签进行路由配置?

2026-06-09 15:451阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计1423个文字,预计阅读时间需要6分钟。

如何高效使用Django中的URL标签进行路由配置?

在使用 Django 开发应用初期,经常会遇到在 urls.py 中硬编码配置地址,以及 views.py 中使用 HttpResponseRedirect() 硬编码转向地址的问题。这种方式存在以下问题:

1. 维护困难:当应用规模扩大或需求变更时,硬编码的地址需要逐一修改,增加了维护成本。

2.扩展性差:如果应用需要添加新的视图或修改现有视图,需要重新编写或修改多个文件中的地址,缺乏灵活性。

3.代码重复:硬编码地址导致代码重复,不利于代码复用。

以下是改进的建议:

1. 使用 URL 路由命名空间:

在 urls.py 文件中,可以通过定义命名空间来简化地址配置。例如:

python

from django.urls import path, include

urlpatterns=[ path('app1/', include('app1.urls', namespace='app1')), path('app2/', include('app2.urls', namespace='app2')),]

在 app1/urls.py 中:

pythonfrom django.urls import pathfrom . import views

urlpatterns=[ path('home/', views.home, name='home'), path('about/', views.about, name='about'),]

这样,在 views.py 中就可以使用命名空间引用视图:

pythonfrom django.shortcuts import redirectfrom django.urls import reverse

def some_view(request): # 使用命名空间引用视图 return redirect(reverse('app1:home'))

2. 使用模板标签:

在模板中,可以使用模板标签动态生成 URL:

Home

这样,当 URL 发生变化时,只需在 urls.py 中修改,模板中的链接会自动更新。

通过这些改进,可以有效地避免硬编码地址,提高应用的维护性和扩展性。

期初用django 开发应用的时候,完全是在urls.py 中硬编码配置地址,在views.py中HttpResponseRedirect()也是硬编码转向地址,当然在template 中也是一样了,这样带来一个问题,如果在urls.py 中修改了某个页面的地址,那么所有的地方(views.py和template中)都要修改。如果是个很大的工程,那么要修改的地方就很多。当然,你也许会选择一个工具,直接查找替换来实现。除此之外呢.....


其实django 本身就提供了这个功能,就是 url 标签,利用 django 的 url 标签来实现这样的功能,在这个模块中:django/conf/urls/defaults


利用url 标签之后,不管urlpatterns里的某个地址叫法怎么改变,Templates里的地址都不用修改了。在模版中调用url标签的时候,需要:{% load url from future %}


比如没有采用url函数的时候:

urlpatterns里定义了资讯的首页地址,

urlpatterns = patterns('',
(r'^article$','news_index' ),
)

Templates里的html为

<a href="/article">资讯</a>

而且不止一个页面,可能有很多个页面使用到资讯的链接,这时你的Templates上就会有许多那样的页面a标签,当有一天,你突然想改变地址的叫法,

urlpatterns = patterns('',
(r'^news$','news_index' ),
)

你会发现,你在Templates中得修改10个<a href="/article">资讯</a>成<a href="/news">资讯</a>

可恨的是那样的标签分布在不同的页面上,有更糟糕的时候就是 你不知道到底有多少个那样的a标签(总不能一个个数嘛)。


有了url情况就大为不一样了,

urlpatterns里定义了资讯的首页地址,

urlpatterns = patterns('',
url(r'^article$','news_index' ,name="news_index"),
)

Templates里的html为

<a href="{%url 'news_index'%}">资讯</a>

你怎么修改urlpatterns的地址,Template都会随着改变,省事了不少。


url的用法也很简单,只要在urlpatterns里使用它,附加一个name,如:

url(r'^article$','news_index' ,name="news_index"),

Templates里 这样使用

{%url 'name'%}

地址链接就能使用了。注意的是name是全局的,你整个urlpatterns里只能一个唯一的name,这个道理应该好理解,就像网站的地址也是唯一性的。

Templates里的用法简单,在views里怎么用呢?以前在没有使用的url函数的时候,可能指向一个地址使用

HttpResponseRedirect("/article")

当然urlpatterns改变地址叫法的时候,所用的views的指向函数的参数都得跟着变。有了url函数,变成:

HttpResponseRedirect(reverse("news_index"))

好处和Template里使用的情形一样的。


当遇到urlpatterns的地址包含有参数的时候,如:

(r'^(?P<year>\d{4})/(?P<month>\d{1,2})/$','news_list' ),

有两个参数,最终的地址如归档的地址​​www.yihaomen.com/2010/02​​

情况变复杂点了,urlpatterns的以上的用法不变:

如何高效使用Django中的URL标签进行路由配置?

url(r'^(?P<year>\d{4})/(?P<month>\d{1,2})/$','news_list',name="news_archive" ),

Templates里的用法就需要改改了,我们把url看成一个方法,结合templates的语法,结果就出来了:

<a href="{%url 'news_archive' 2010 02%}">2010年02月</a>
或者这样:
<a href="{%url 'news_archive' year=2010 month=02%}">2010年02月</a>

当然,在你后台的views.py 中的方法上也必须有这两个参数,比如

def news_list(request,year,month):
print 'year:',year
print 'monty:',month
......

后面的2010, 02 就是参数了,参数之间用逗号隔开,多少个参数用法都一样的。当然,2010 02 参数是某个实体获得的,具体的情况具体分析。而在views呢,有了参数怎么写,万变不离宗

from django.core.urlresolvers import reverse
......
reverse("news_archive",kwargs={"year":2010,"month":02})

比如: return HttpResponseRedirect(reverse("news_archive",kwargs={"year":2010,"month":02}))

即可,最后解析出来的地址为“/2010/02”。


由此看出,在用 django开发应用的时候,url 标签是个很灵活的东西,应该多用,也为以后维护带来方便。


​​参考​​






标签:使用期初

本文共计1423个文字,预计阅读时间需要6分钟。

如何高效使用Django中的URL标签进行路由配置?

在使用 Django 开发应用初期,经常会遇到在 urls.py 中硬编码配置地址,以及 views.py 中使用 HttpResponseRedirect() 硬编码转向地址的问题。这种方式存在以下问题:

1. 维护困难:当应用规模扩大或需求变更时,硬编码的地址需要逐一修改,增加了维护成本。

2.扩展性差:如果应用需要添加新的视图或修改现有视图,需要重新编写或修改多个文件中的地址,缺乏灵活性。

3.代码重复:硬编码地址导致代码重复,不利于代码复用。

以下是改进的建议:

1. 使用 URL 路由命名空间:

在 urls.py 文件中,可以通过定义命名空间来简化地址配置。例如:

python

from django.urls import path, include

urlpatterns=[ path('app1/', include('app1.urls', namespace='app1')), path('app2/', include('app2.urls', namespace='app2')),]

在 app1/urls.py 中:

pythonfrom django.urls import pathfrom . import views

urlpatterns=[ path('home/', views.home, name='home'), path('about/', views.about, name='about'),]

这样,在 views.py 中就可以使用命名空间引用视图:

pythonfrom django.shortcuts import redirectfrom django.urls import reverse

def some_view(request): # 使用命名空间引用视图 return redirect(reverse('app1:home'))

2. 使用模板标签:

在模板中,可以使用模板标签动态生成 URL:

Home

这样,当 URL 发生变化时,只需在 urls.py 中修改,模板中的链接会自动更新。

通过这些改进,可以有效地避免硬编码地址,提高应用的维护性和扩展性。

期初用django 开发应用的时候,完全是在urls.py 中硬编码配置地址,在views.py中HttpResponseRedirect()也是硬编码转向地址,当然在template 中也是一样了,这样带来一个问题,如果在urls.py 中修改了某个页面的地址,那么所有的地方(views.py和template中)都要修改。如果是个很大的工程,那么要修改的地方就很多。当然,你也许会选择一个工具,直接查找替换来实现。除此之外呢.....


其实django 本身就提供了这个功能,就是 url 标签,利用 django 的 url 标签来实现这样的功能,在这个模块中:django/conf/urls/defaults


利用url 标签之后,不管urlpatterns里的某个地址叫法怎么改变,Templates里的地址都不用修改了。在模版中调用url标签的时候,需要:{% load url from future %}


比如没有采用url函数的时候:

urlpatterns里定义了资讯的首页地址,

urlpatterns = patterns('',
(r'^article$','news_index' ),
)

Templates里的html为

<a href="/article">资讯</a>

而且不止一个页面,可能有很多个页面使用到资讯的链接,这时你的Templates上就会有许多那样的页面a标签,当有一天,你突然想改变地址的叫法,

urlpatterns = patterns('',
(r'^news$','news_index' ),
)

你会发现,你在Templates中得修改10个<a href="/article">资讯</a>成<a href="/news">资讯</a>

可恨的是那样的标签分布在不同的页面上,有更糟糕的时候就是 你不知道到底有多少个那样的a标签(总不能一个个数嘛)。


有了url情况就大为不一样了,

urlpatterns里定义了资讯的首页地址,

urlpatterns = patterns('',
url(r'^article$','news_index' ,name="news_index"),
)

Templates里的html为

<a href="{%url 'news_index'%}">资讯</a>

你怎么修改urlpatterns的地址,Template都会随着改变,省事了不少。


url的用法也很简单,只要在urlpatterns里使用它,附加一个name,如:

url(r'^article$','news_index' ,name="news_index"),

Templates里 这样使用

{%url 'name'%}

地址链接就能使用了。注意的是name是全局的,你整个urlpatterns里只能一个唯一的name,这个道理应该好理解,就像网站的地址也是唯一性的。

Templates里的用法简单,在views里怎么用呢?以前在没有使用的url函数的时候,可能指向一个地址使用

HttpResponseRedirect("/article")

当然urlpatterns改变地址叫法的时候,所用的views的指向函数的参数都得跟着变。有了url函数,变成:

HttpResponseRedirect(reverse("news_index"))

好处和Template里使用的情形一样的。


当遇到urlpatterns的地址包含有参数的时候,如:

(r'^(?P<year>\d{4})/(?P<month>\d{1,2})/$','news_list' ),

有两个参数,最终的地址如归档的地址​​www.yihaomen.com/2010/02​​

情况变复杂点了,urlpatterns的以上的用法不变:

如何高效使用Django中的URL标签进行路由配置?

url(r'^(?P<year>\d{4})/(?P<month>\d{1,2})/$','news_list',name="news_archive" ),

Templates里的用法就需要改改了,我们把url看成一个方法,结合templates的语法,结果就出来了:

<a href="{%url 'news_archive' 2010 02%}">2010年02月</a>
或者这样:
<a href="{%url 'news_archive' year=2010 month=02%}">2010年02月</a>

当然,在你后台的views.py 中的方法上也必须有这两个参数,比如

def news_list(request,year,month):
print 'year:',year
print 'monty:',month
......

后面的2010, 02 就是参数了,参数之间用逗号隔开,多少个参数用法都一样的。当然,2010 02 参数是某个实体获得的,具体的情况具体分析。而在views呢,有了参数怎么写,万变不离宗

from django.core.urlresolvers import reverse
......
reverse("news_archive",kwargs={"year":2010,"month":02})

比如: return HttpResponseRedirect(reverse("news_archive",kwargs={"year":2010,"month":02}))

即可,最后解析出来的地址为“/2010/02”。


由此看出,在用 django开发应用的时候,url 标签是个很灵活的东西,应该多用,也为以后维护带来方便。


​​参考​​






标签:使用期初