Django 后台带有字典的列表数据与页面js交互实例
1、这里只是简单介绍一下Django的view如何跟js进行交互,首先,进入用户明细的时候会进入一个页面,叫用户信息表,里面包含了用户学习的课程和所得到的分数,每门课程对应一个分数,其中课程用下拉框依次显示,选择课程时动态显示课程的分数,django view部分代码如下:
def user_info(request, userid):
if request.method == "GET":
user = User.objects.get(userid=userid)
user_info = UserInfo.objects.get(userid=userid)
content = {"user": user, "user_info": user_info}
detail_data = {}
data = []
for detail in user_info:
detail_data['course'] = detail.course
detail_data['score'] = str(detail.score)
data.append(json.dumps(detail_data, ensure_ascii=False))
content['detail'] = data
return render(request, "user/user_info/user_info.html", content)
其中,需注意的是下面这段代码,
(1)、定义一个空的字典为detail_data,接着再定义一个空的列表data,循环得到每个用户信息的详情,也就是用户的每个课程对应的每个分数,分别把值添加进字典里面去。
(2)、后面在把字典的值通过json.dumps转换为json格式,这样才能给html页面的js进行交互,而且如果有中文的话,需要在后面加个ensure_ascii=False参数,不然的话js得到的数据不是我们想得到的数据。
(3)、最后,再把转成json的字典数据添加进列表data中,最后通过content[‘detail’]=data把这个列表传到页面上,供js调用。
detail_data = {}
data = []
for detail in user_info:
detail_data['course'] = detail.course
detail_data['score'] = str(detail.score)
data.append(json.dumps(detail_data, ensure_ascii=False))
content['detail'] = data
2、接下来看下html中如何处理上面传过的detail数据,其中课程用下拉框依次显示,选择课程时动态显示课程的分数,代码如下:
<script
function select() {
var course =$('#course option:selected').val();
var details = {{ detail|safe }}
for(var detail in details){
var data = JSON.parse(details[detail]);
if(course == data.course){
$('#score').html(data.score);
}
}
}
</script
代码解析一下:
(1)、其中获取下拉框选择的课程值,赋给一个变量course,接着把传过来界面的detail,赋给一个变量details,注意这里必须要用{{ detail|safe }},不然取出来的数据会不是想要的。
(2)、接着,循环上面得到的变量,也就是一个带有字典的列表,循环就得到每一个带有课程和课程分数的字典,因为在view底下是把每一个字典转换为json格式,所以现在必须把循环得到每一个字典通过json解析得到其对应的,通过JSON.parse(details[detail]),否则也是取不到对应的数据。
(3)、通过页面下拉框选择的课程值,跟取到的每个课程的分数做比较,相等的话,就取出对应课程的分数,填充进页面中。
3、Django和js交互的网上例子太少,这里积累一下,以上内容仅供学习参考,谢谢!主要还是自己去尝试。
补充知识:django 后台数据直接交给页面
<html
<head
<title 运维平台</title
<link rel="stylesheet" type="text/css" href="/static/Css/Monitor/addmqmonitor.css" rel="external nofollow"
<link rel="stylesheet" type="text/css" href="/static/Css/Public/header.css" rel="external nofollow" rel="external nofollow"
<link rel="stylesheet" type="text/css" href="/static/Css/Public/menu.css" rel="external nofollow" rel="external nofollow"
</head
<body
<include file="Public:header"/
<div class="content"
<include file="Public:menu"/
<div class="con fl"
<form id="condition" action="/addmqmonitor/" method="post"
<label class="condition" 应用</label <input type="text" name="app" class="equipment_sz"
<label class="condition" 队列管理器</label <input type="text" name="qmgr" class="equipment_sz"
<label class="condition" 通道名称</label <input type="text" name="channel" class="equipment_sz"
<br /
<label class="condition" IPADDR</label <input type="text" name="ipaddr" class="equipment_sz"
<label class="condition" PORT</label <input type="text" name="port" class="equipment_sz"
<label class="condition" 队列监控阈值</label <input type="text" name="depth" class="equipment_sz"
<label class="condition" 是否监控</label <input type="text" name="flag" class="equipment_sz"
<br /
<input type="submit" value="设备添加" class="equipment_add_btn"
</form
</div
</div
</body
<script type="text/javascript" src="/static/Js/jquery-2.2.2.min.js" </script
<!-- <script type="text/javascript" src="/static/Js/Equipment/addEquipment.js" </script --
</html
def addmqmonitor(req):
print req.get_full_path()
app= req.POST['app']
qmgr= req.POST['qmgr']
channel= req.POST['channel']
ipaddr= req.POST['ipaddr']
port= req.POST['port']
depth= req.POST['depth']
flag= req.POST['flag']
conn= MySQLdb.connect(
host='127.0.0.1',
port = 3306,
user='root',
passwd='1234567',
db ='DEVOPS',
charset="UTF8"
)
cursor = conn.cursor()
sql = "insert into mon_mq(name,qmgr,channel,ipaddr,port,depth,flag) values('%s','%s','%s','%s','%s','%s','%s')" % (app,qmgr,channel,ipaddr,port,depth,flag)
cursor.execute(sql)
conn.commit()
a = cursor.execute("select name,qmgr,channel,ipaddr,port,flag from mon_mq" )
info = cursor.fetchall()
print info
print type(info)
return render(req,'listmqinfo.html',{'info':info})
[root@yyjk templates]#cat listmqinfo.html
<html
<head
<title 运维平台</title
<link rel="stylesheet" type="text/css" href="/static/Css/Equipment/modifyBtn.css" rel="external nofollow"
<link rel="stylesheet" type="text/css" href="/static/Css/Public/header.css" rel="external nofollow" rel="external nofollow"
<link rel="stylesheet" type="text/css" href="/static/Css/Public/menu.css" rel="external nofollow" rel="external nofollow"
</head
<table border="10"
{% for x in info %}
<tr
<th {{x.0}}</th
<th {{x.1}}</th
<td {{x.2}}</td
<td {{x.3}}</td
<td {{x.4}}</td
<td {{x.5}}</td
</tr
{% endfor %}
</table
以上这篇Django 后台带有字典的列表数据与页面js交互实例就是小编分享给大家的全部内容了,希望能给大家一个参考。
- CentOS 6 使用 yum 安装MongoDB及服务器端配置
- java处理高并发高负载类网站的优化方法
- 每一个程序员需要了解的10个Linux命令
- php_curl.dll libssh2.dll 始终无法加载的原因 及解决办法
- ant安装、环境变量配置及验证
- MySQL性能优化的最佳20+条经验
- 剑指offer面试题7——用两个栈实现队列
- String类中你不知道的知识
- Hibernate 不同数据库的连接及SQL方言
- Java中被你忽视的四种引用
- 使用Python和R语言从头开始理解和编写神经网络
- 深度学习中训练参数的调节技巧
- 大型网站技术架构!
- 理解js中的原型链,prototype与__proto__的关系
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 【C++简明教程】C++基本语法
- 【多目标跟踪】搞不懂MOT数据集,会跑代码有啥用!
- 手工 - 内网信息收集
- 使用ffmpeg压缩视频之烦和fun
- 一文学会 Web Service漏洞挖掘!
- 【实战项目代码分享】计算机视觉入门教程&实战项目代码
- Linux部署DNS服务器
- 【C++简明教程】C++简介与环境配置
- PDF 的各种操作,我用 Python 来实现(附网站和操作指导)
- Python中map()函数用法
- 谈谈不同思路下造就的不同产品与公司形态
- OpenCV 处理中文路径、绘制中文文字的烦恼,这里通通帮你解决!
- 如何快速分析大型系统架构?
- Linux小技巧、文件查找、修改、读取
- 我在赏金计划中发现的RACE条件漏洞