django跳转页面传参的实现


Posted in Python onSeptember 17, 2020

一、情景

    eg:查看一条数据的详情,需要跳转页面,并进行传值

二、思路

方式1:触发详情按钮时,Js获取到该条数据的id值,并传递给url,后台接受到该请求,通过id查询到这条数据。并返回一个json串给前端。前端拿到数据进行处理,映射给页面。

方式2:触发详情按钮时,同时前端进行本地保存当前数据(sessionstorage\localstorage),跳转页面后,前端直接从storage当前取值并回显。

           ①关于数据存储:

            sessionstorage:数据存储,关闭窗口的同时,清除数据

            localstorage:数据存储,未定义过期时间,一直存在本地

需要注意的是:当前端页面发生跳转时,资源都会被重载,当未进行传值的情况下,无法跨页面加载数据。

三 实现:

方式1:URL传值

①获取id后直接传递给URL

window.location.href=`index.html?nid=${id}`;

②再跳转到index.html的js中获取到该并id解析

(function() {
 window.onload = function() {
    var url=window.location.href;
    var url_param = url.split("?")[1];
    var url_param_arr = url_param.split("=");
    var nid ={nid:url_param_arr[1]};
    preview_index(nid);//处理函数,发送请求
 }
})();

方式2:本地存储

①存

//本地存储
        var storage = window.sessionStorage;
        storage['index_name'] = $('#index_name').val();
        storage['index_title'] = $('#index_title').val();
        storage['index_content'] = $('#index_content').val();

②读取

var storage=window.sessionStorage;
title=storage.index_title

四、其他方法

1、如果在反转url的时候,需要添加参数,那么可以通过传递'kwargs'参数到'reverse'函数中。实例代码:

urls.py

from django.urls import path, re_path
from app01 import views

urlpatterns = [
  path('article/<year>/<month>/',views.article,name='article'),
  path('', views.Login.as_view(), name="login"),
  ]

views.py

from django.shortcuts import HttpResponse, redirect, reverse
from django.contrib.auth.models import User, 
from django.views.generic import View
from django.contrib.auth import authenticate, login,

class Login(View):
  def get(self, request):
    return render(request, 'login.html')

  def post(self, request):
    username = request.POST.get('username')
    passwd = request.POST.get('passwd')
    user = authenticate(request, username=username, password=passwd)
    if user is not None:
      if user.is_active:
        login(request, user)
        # 登录成功跳转页面
        return redirect(reverse('article', kwargs={'year': 2019, 'month': 12}))
      else:
        err_msg = '用户未激活,请联系管理员进行激活'
    else:
      err_msg = '用户名或密码有误'
    return render(request, 'login.html', {"err_msg": err_msg, "username": username})


def article(request, year, month):
  return HttpResponse('您查询的文章日期是:%s年%s月' %(year, month))

2、如果想要添加查询字符串的参数,则必须手动的进行拼接。实例代码如下:

login_url = reverse('login')+"?next=/"

到此这篇关于django跳转页面传参的实现的文章就介绍到这了,更多相关django跳转页面传参内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python抓取京东商城手机列表url实例代码
Dec 18 Python
python使用in操作符时元组和数组的区别分析
May 19 Python
Python实现查找系统盘中需要找的字符
Jul 14 Python
python3中bytes和string之间的互相转换
Feb 09 Python
Python 实现淘宝秒杀的示例代码
Jan 02 Python
OpenCV HSV颜色识别及HSV基本颜色分量范围
Mar 22 Python
Python 实现数据结构-堆栈和队列的操作方法
Jul 17 Python
python中的itertools的使用详解
Jan 13 Python
基于Python fminunc 的替代方法
Feb 29 Python
通过实例解析Python return运行原理
Mar 04 Python
利用python清除移动硬盘中的临时文件
Oct 28 Python
python中复数的共轭复数知识点总结
Dec 06 Python
解决Ubuntu18中的pycharm不能调用tensorflow-gpu的问题
Sep 17 #Python
Django mysqlclient安装和使用详解
Sep 17 #Python
Pycharm2020最新激活码|永久激活(附最新激活码和插件的详细教程)
Sep 29 #Python
Django返回HTML文件的实现方法
Sep 17 #Python
Pycharm新手使用教程(图文详解)
Sep 17 #Python
Django修改app名称和数据表迁移方案实现
Sep 17 #Python
Python request中文乱码问题解决方案
Sep 17 #Python
You might like
用文本文件实现的动态实时发布新闻的程序
2006/10/09 PHP
浅谈PHP与C#的值类型指向区别的详解
2013/05/21 PHP
PHP代码保护--Zend Guard的使用详解
2013/06/03 PHP
注意:php5.4删除了session_unregister函数
2013/08/05 PHP
php遍历树的常用方法汇总
2015/06/18 PHP
php判断str字符串是否是xml格式数据的方法示例
2017/07/26 PHP
TP5框架实现上传多张图片的方法分析
2020/03/29 PHP
javascript 关闭IE6、IE7
2009/06/01 Javascript
Eval and new funciton not the same thing
2012/12/27 Javascript
javascript操作table(insertRow,deleteRow,insertCell,deleteCell方法详解)
2013/12/16 Javascript
window.location.href中url中数据量太大时的解决方法
2013/12/23 Javascript
javascript属性访问表达式用法分析
2015/04/25 Javascript
基于AngularJS+HTML+Groovy实现登录功能
2016/02/17 Javascript
基于Javascript实现二级联动菜单效果
2016/03/04 Javascript
jquery跟随屏幕滚动效果的实现代码
2016/04/13 Javascript
30分钟快速掌握Bootstrap框架
2016/05/24 Javascript
JavaScript数组的5种迭代方法
2017/09/29 Javascript
node结合swig渲染摸板的方法
2018/04/11 Javascript
关于HTML5的data-*自定义属性的总结
2018/05/05 Javascript
详解滑动穿透(锁body)终极探索
2019/04/16 Javascript
微信JSSDK实现打开摄像头拍照再将相片保存到服务器
2019/11/15 Javascript
关于Js中new操作符的作用详解
2021/02/21 Javascript
[00:33]2016完美“圣”典风云人物:BurNIng宣传片
2016/12/10 DOTA
用Python实现web端用户登录和注册功能的教程
2015/04/30 Python
python实现决策树
2017/12/21 Python
TensorFlow变量管理详解
2018/03/10 Python
查看端口并杀进程python脚本代码
2019/12/17 Python
tensorflow入门:TFRecordDataset变长数据的batch读取详解
2020/01/20 Python
Python3以GitHub为例来实现模拟登录和爬取的实例讲解
2020/07/30 Python
html5使用canvas实现跟随光标跳动的火焰效果
2014/01/07 HTML / CSS
phonegap常用事件总结(必看篇)
2017/03/31 HTML / CSS
Muziker英国:中欧最大的音乐家商店
2020/02/05 全球购物
一套软件开发工程师笔试题
2015/05/18 面试题
毕业班班主任工作总结2015
2015/07/23 职场文书
解决Django transaction进行事务管理踩过的坑
2021/04/24 Python
Python 机器学习工具包SKlearn的安装与使用
2021/05/14 Python