创建项目和应用
django-admin startproject zqxt_views(项目名) cd zqxt_views python manage.py startapp calc(应用名)
————?1.采用/add?a=4&b=5这样GET方法进行—————————
修改 calc/view.py文件
from django.shortcuts import render from django.http import HttpResponse def add(request): a = request.GET['a'] b = request.GET['b'] c = int(a)+int(b) return HttpResponse(str(c))
修改 zqxt_views/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'^admin/', admin.site.urls), ]
打开服务器并访问
python manage.py runserver 8003
打开网址
http://127.0.0.1:8003/add/?a=4&b=5
————?2.采用/add/3/4这样的网址的方式—————————
修改 calc/views.py 文件,再定义一个add2函数
def add2(request, a, b): c = int(a) + int(b) return HttpResponse(str(c))
接着修改 zqxt_views/urls.py 文件,再添加一个新的 url
url(r'^add/(\d+)/(\d+)/$',calc_views.add2,name='add2'),
我们可以看到网址中多了 (\d+), 正则表达式中 \d 代表一个数字,+ 代表一个或多个前面的字符,写在一起 \d+ 就是一个或多个数字,用括号括起来的意思是保存为一个子组,每一个子组将作为一个参数,被 views.py 中的对应视图函数接收。
我们再访问 http://127.0.0.1:8003/add/4/5/ 就可以看到和刚才同样的效果,但是这回网址更优雅了
打开 zqxt_views/urls.py
from django.conf.urls import url from django.contrib import admin from calc import views as calc_views urlpatterns = [ url(r'^admin/', admin.site.urls), url(r'^add/$',calc_views.add,name='add'), url(r'^add/(\d+)/(\d+)/$',calc_views.add2,name='add2'), ]
在 url(r'^add/$',calc_views.add,name='add'),中,name='add'是用来干什么滴啊?
简单说,name可用于在templates,models,views……中得到对应的网址,相当于给“网址取了一个名字”,只要名字不变,网址变了也能通过名字获取到。
为了继续弄清楚这个问题,我们先建立一个首页的视图和url
修改 *calc/views.py*
from django.http import HttpResponse from django.shortcuts import render def index(request): return render(request, 'home.html')
render 是渲染模板
将‘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会自动找到INSTALLED_APPS中列出的各个app下的templates中的文件。
提示:DEBUG=True的时候,Django可以自动找到各个app下static文件中的静态文件(js,css,图片,资源)
我们在calc这个app中新建一个templates文件夹,在templates中新建一个home.html
文件 calc/templates/home.html 中写入以下内容
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>title</title> </head> <body> <a href="/add/4/5" rel="external nofollow" >计算 4 + 5 </a> </body> </html>
修改zqxt_views/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), ]
运行服务器python manage.py runserver 8004,访问http://127.0.0.1:8004/
我们计算加法的时候用的是 /add/4/5/ ,后来需求发生变化,比如改成 /4_add_5/,但在网页中,代码中很多地方都写死的 /add/4/5/,比如模板中可能是这么写的
<a href="/add/4/5/" rel="external nofollow" rel="external nofollow" >计算 4+5</a>
如果这样写“死网址”,会使得在改了网址(正则)后,模板(template),视图(views.py,比如用于URL跳转),模型(models.py,获取记录访问地址等)用了此网址的,都必须进行相应的更改,修改的代价很大,一不小心,有的地方没改过来,就不能用了。
reverse 接收 url 中的 name 作为第一个参数,我们在代码中就可以通过 reverse() 来获取对应的网址
我们在终端上输入:python manage.py shell
>>> from django.core.urlresolvers import reverse # django 1.4.x - django 1.10.x
或者
>>> from django.urls import reverse # Django 1.10.x - Django 2.x 新的,更加规范了 >>> reverse('add2', args=(4,5)) u'/add/4/5/' >>> reverse('add2', args=(444,555)) u'/add/444/555/'
在网页模板中也是一样,可以很方便的使用。
不带参数的: {% url 'name' %} 带参数的:参数可以是变量名 {% url 'name' 参数 %}
因此,我们将:templates/home.html 中
<a href="/add/4/5/" rel="external nofollow" rel="external nofollow" >link</a>改成 <a href="{% url 'add2' 4 5 %}" rel="external nofollow" >link</a>
这样的话,当 urls.py 进行更改,前提是不改 name(这个参数设定好后不要轻易改),获取的网址也会动态地跟着变,比如改成:
url(r'^new_add/(\d+)/(\d+)/$', calc_views.add2, name='add2'),
{% url ‘add2' 4 5 %}就会被渲染成/new_add/4/5/
有另外一个情况,如果我们原来收藏的一个网址,现在这个网址被废了,现在有个新的网址,如何让以前的/add/3/4自动跳转到新的网址那?
具体的思路是,在view.py写一个跳转方法:
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)) )
以上这篇Django url,从一个页面调到另个页面的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。
Django url,从一个页面调到另个页面的方法
- Author -
NeXTSTEP110声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@