Django框架——进阶之AJAX
<script>
$("#b1").on("click", function () {
// 点击 id是b1的按钮要做的事儿
var i1 = $("#i1").val();
var i2 = $("#i2").val();
// 往后端发数据
$.ajax({
url: "/ajax_add/",
type: "get",
data: {"i1": i1, "i2": i2},
success: function (arg) {
{#alert(arg);#} //arg 是后端经过各种业务逻辑计算之后返回的数据
// 把返回的结果填充到 id是i3的input框中
$("#i3").val(arg);
}
})
});
</script>
<td>{{ p.birthday|date:'Y-m-d' }}</td> //使用date:'Y-m-d' 可以格式化时间格式
结果如下:

如果不加的话显示如下:

ajax使用在前后端交互的时候要注意的转换事项:
1.
例如:一个html里面的jQuery的ajax如下(看看错误在哪里):
$.ajax({
url: "/test/",
type: "post",
data: {"name": "小黑", "sb":[1,2,3]}, //错误:可以看到此时的data 的sb的value 是一个列表,在这里从前端的jQuery的ajax是转不了这个value到后端的,因为相对于data来说,
//已经是一个多层的数据类型了,这是不行的,所以这里需要通过jQuery的JSON将sb的value转换成为字符串才行!!修改如下:
//方法一:data: {"name": "小黑", "sb":JSON.stringify([1,2,3])}, 只要value不是字符串和数字的,都需要用JSON.stringify()进行序列化转为JSON
//方法二:在data之前添加 traditional: true,的属性也可以实现sb自动JSON化 。但是如果,sb的value是[[1,2,3] , [4,5,6]]双层或多层的话,ajax返回到
//python后端的值还是有问题,应该给是["1,2,3", "4,5,6"]
success: function (data) {
alert(data);
}
})
2.
后端的view.py文件写如下(找出错误在哪里):
def test(request):
if request.method == "POST":
name = request.POST.get("name")
sb = request.POST.getlist("sb")
print(name)
print(sb, type(sb)) ret = { //错误:可以看到这里的返回值是ret,而ret的多层格式的一个字典类型,如果经过下面的HttpResponse返回不了这个数据段到前端的ajax的,因为,在网络传输中是不能这样传输的,
"status": 0, //所以需要,在这里进行JSON格式的转换,如下:
"data": [
{"name": "张三", "age": 18},
{"name": "李四", "age": 28},
]
}
return HttpResponse(ret) return render(request, "test.html")
-----------------------------------------------------------------------------------------------------------------------
ret = {
"status": 0,
"data": [
{"name": "张三", "age": 18},
{"name": "李四", "age": 28},
]
}
ret_str = json.dumps(ret) //在python后端,将多层的数据类型序列化为JSON格式,之后再进行传输,这还没有完,因为,在前端还需要对从这里转出去JSON进行反序列化,如下:
return HttpResponse(ret_str)
-----------------------------------------------------------------------------------------------------------------
看看:在前端中,就需要添加dataType:"json"类型或者使用JSON.parse()反序列化
$("#b1").on("click", function () {
$.ajax({
url: "/test/",
type: "post",
dataType: "json", //方法一:这个表示将从后端传来的JSON数据默认反序列化解析
traditional: true,
data: {"name": "小黑", "sb":[1,2,3,4]},
success: function (data) {
// 把后端返回的数据反序列化成JS中的对象
// var data = JSON.parse(data); //方法二:这个表示直接将后端返回的数据直接解析
if (data.status === 0){
// 这次请求成功
alert(data.data);
}else {
// 请求出错
alert(data.error);
}
}
})
});
Django框架——进阶之AJAX的更多相关文章
- Django框架 之 基于Ajax中csrf跨站请求伪造
Django框架 之 基于Ajax中csrf跨站请求伪造 ajax中csrf跨站请求伪造 方式一 1 2 3 $.ajaxSetup({ data: {csrfmiddlewaretoken: ...
- django框架进阶-中间件-长期维护
################## 为什么使用中间件? ####################### 先说几个需求, 1,url的白名单,url=[ "XX"] ...
- django框架进阶-AJAX-长期维护
################## 预备知识---json ####################### 预备知识,json 什么是json?这是一种数据格式,和语言没有关系, 为什么 ...
- Django框架详细介绍---AJAX
一.概述 1.什么是JSON JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据交换格式 JSON 独立于语言 * ...
- django框架进阶-解决跨域问题
####################################### """ 一.为什么会有跨域问题? 是因为浏览器的同源策略是对ajax请求进行阻拦了,但是不 ...
- Django框架进阶
Django ORM那些相关操作 Django中ORM介绍和字段及字段参数 Cookie.Session和自定义分页 Django 中间件 AJAX Django form表单 Django的认证系统 ...
- django框架进阶-CSRF认证
############################################### """ django中csrf的实现机制 #第一步:django第一次响应 ...
- django框架进阶-分页-长期维护
################## 分页 ####################### 分页, django有自己内置的分页,但是功能不是很强大,所以自己写一个分页, web页面数据非常 ...
- django框架进阶-auth认证系统-长期维护
################## django的认证系统 ####################### 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统.此时我们需要 ...
随机推荐
- 控制类名(className属性)
className 属性设置或返回元素的class 属性. 语法: object.className = classname 作用: 1.获取元素的class 属性 2. 为网页内的某个元素指定一个c ...
- RN中webview的一些思考
刚开始只是对接一下RN,h5部分,嵌套在RN里的webview里需要隐藏一些原生的按钮,遇到很多沟通上的问题,本来没使用RN之前,也是嵌套在webview里,也没什么问题,突然RN嵌套就有问题了,对方 ...
- GitHub:Python
ylbtech-GitHub:Python 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 1. https://github.com/python 2. 6 ...
- background-color 属性
background-color:transparent;是什么意思?? 把背景颜色设为透明色
- 自定义一个数组对象工具demo
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 关于 About
关于我 我是 Ivy,目前武汉大学 GIS 专业在读硕士研究生,业余渣程序媛. 写了一些不起眼的代码(参看我的 GitHub),做了一些不起眼的小研究(参看我的 ResearchGate). 关于本站 ...
- Ubunut16.04 安装 Theano+GPU
1. 更新NVIDIA显卡驱动 安装好系统之后首先在系统更新管理器中更新显卡驱动,如下图 点击Apply Changes 2. 安装numpy,scipy,theano pip安装即可 sudo ...
- [笔记] 基于nvidia/cuda的深度学习基础镜像构建流程 V0.2
之前的[笔记] 基于nvidia/cuda的深度学习基础镜像构建流程已经Out了,以这篇为准. 基于NVidia官方的nvidia/cuda image,构建适用于Deep Learning的基础im ...
- Visual Studio 展开和折叠代码快捷键
每个cs文件代码太多,总数找不到方法.每次都是手动一个一个方法折叠手疼,赶紧搜索折叠展开快捷键. Ctrl + M + O: 折叠所有方法 Ctrl + M + M: 折叠或者展开当前方法 Ctr ...
- Opencv实现的陷波滤波器
在本示例中,共设计了三个函数,分别是巴特沃斯滤波器BLPF().巴特沃斯陷波滤波器notchFilter_BTW().高斯陷波滤波器notchFilter_GAUSS() 巴特沃斯陷波滤波器参见书上6 ...