Django url,从一个页面调到另个页面的方法
作者:NeXTSTEP110 发布时间:2021-08-08 03:51:51
创建项目和应用
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))
)
来源:https://blog.csdn.net/NeXTSTEP110/article/details/79846116


猜你喜欢
- 迪杰斯特拉(Dijkstra)算法主要是针对没有负值的有向图,求解其中的单一起点到其他顶点的最短路径算法。1 算法原理迪杰斯特拉(Dijks
- 做数据分析、科学计算等离不开工具、语言的使用,目前最流行的数据语言,无非是MATLAB,R语言,Python这三种语言,但今天小编简单总结了
- 最近在工作上用到Python的pandas库来处理excel文件,遇到列转行的问题。找了一番资料后成功了,记录一下。1. 如果需要 * 的只有
- 一般安装完Python后,我会先装一些常用的Package。做个笔记,记录下来,以备查询:Web FrameWorksTornado,访问:
- 一维线性拟合数据为y=4x+5加上噪音结果:import numpy as npfrom mpl_toolkits.mplot3d impo
- 前几天和一个小伙伴交流了一下nodejs中epoll和处理请求的一些知识,今天简单来聊一下nodejs处理请求的逻辑。我们从listen函数
- 在ASP中,直接使用“Insert into” 语句与使用ADO中AddNew方法有什么区别?哪一种更好呢?AddNew方法的实质就是封装了
- Oracle数据库先创建一个表和添加一些数据1.先在Oracle数据库中创建一个student表:create table student(
- 前言激活函数在机器学习中常常用在神经网络隐含层节点与神经网络的输出层节点上,激活函数的作用是赋予神经网络更多的非线性因素,如果不用激励函数,
- 创建 var d=new Date(); 要注意的是在JavaScript中月份的值是从0到11(0表示1月)。 设置日期和时间值 设置日期
- 今天弄了一天,总算把win2003下的问题给解决了, LoadModule php5_module E:\server\php528\php
- 因时间问题不可能一次写的很多,但我们会经常更新,方便大家。希望学习编程的朋友不要因为从网站复制了代码,而不能正常的运行而放弃。其实老鸟也是经
- 什么是目标检测目标检测关注图像 * 定的物体目标,需要同时解决解决定位(localization) + 识别(Recognition)。相比分
- mark标记在实际工作中,我们要写的自动化用例会比较多,也不会都放在一个py文件中,如果有几十个py文件,上百个方法,而我们只想运行当中部分
- 最近在刚从tensorflow转入pytorch,对于自定义的nn.Module 碰到了个问题,即使把模组 modle=Model().cu
- 准备开始学习Python,但是刚准备环境搭建时就遇到了下面的错误:仔细的看了看,说是缺少DLL。对于这个问题的解决办法:方法一:1. 在安装
- 使用ewebeditor作为后台编辑器时,尤其是一个页面中使用多次该编辑器时,在提交数据时,可能会遇到数据被重复提交的情况。搜索找来一些解决
- 本文实例讲述了Python实现对PPT文件进行截图操作的方法。分享给大家供大家参考。具体分析如下:下面的代码可以为powerpoint文件p
- 掌握一些技巧,可尽量提高Python程序性能,也可以避免不必要的资源浪费。1、使用局部变量尽量使用局部变量代替全局变量:便于维护,提高性能并
- 在对于时间准确度的把握上,为了使操作的更加细化,很多人习惯把时间精确到秒。但在实际程序操作中,虽然秒数方便我们的查阅,但是计算机并不能直接的