Ajax传递json数据简介和一个需要注意的小问题
Ajax传递json数据
Ajax操作与json数据格式在实际中的运用十分广泛,本文为大家介绍一个两者相结合的小案例:
项目结构
我们新建一个Django项目,在里面创建一个名为app01
的应用:
python manage.py startapp app01
路由——我们在全局的urls.py
文件中加入一个index
路由:
from django.contrib import admin
from django.urls import path,re_path
from app01 import views
urlpatterns = [
path('admin/', admin.site.urls),
re_path('^index/$',views.index ),
]
视图函数——视图函数中定义一个名为index
的函数:
from django.shortcuts import render,HttpResponse
def index(request):
if request.method == 'POST':
#请求报文中的请求体
print('body:',request.body)
#当contentType为urlencoded的时候,request.POST才有值
print('POST:',request.POST)
return HttpResponse('OK!')
return render(request,'index.html')
这里需要注意一下,windows中,在templates
包中加入index.html
文件之前需要在全局的settings.py
文件中的TEMPLATES
列表里的DIRS
改成下面这个列表而不是默认的空列表:
[os.path.join(BASE_DIR,'templates')]
然后,我们在templates
包中加入index.html
文件。
在里面加一个button:
<form method="post" >
<input id="btn" type="button" value="Ajax传递json数据">
</form>
js的代码如下:
$('#btn').click(function () {
$.ajax({
url:"/index/",
type:"post",
//告诉服务器本次数据编码用json格式
contentType:'application/json',
//对数据进行json序列化
data:JSON.stringify({a:1, b:2}),
success:function (data) {
console.log(data)
}
})
});
过程详解
这里,我们给button
定义一个click
事件,在进行ajax操作的时contentType
格式定义为'application/json'
,也就是说告诉服务器本次数据编码用json格式,接着将需要传递的数据进行json的序列化,然后传给后台。
在视图函数中,我们打印两个数据:request.body
与request.POST
,需要注意:request.POST
仅有在contentType
为urlencoded
的时候才有值,如果前端传递的数据格式为json
的时候只能在request.body
中看到数据。视图函数中打印的结果如下:
我们在浏览器中的NetWork中可以查看到contentType
的值为json
:
一个小问题
在前端部分,如果我们把input的type由button
改为submit
的话,上面的结果会出现下面的结果:
上面可以看到,我们的视图函数将body与POST结果打印了两次,而且contentType
的值竟然变成了urlencoded
!
这是因为submit会自动提交一次,而且“结果”会有异常:明明浏览器中的contentType
的值变成了urlencoded
,但是POST仍然打印不出来值!
因此,如果表单在点击提交按钮后需要用JS进行处理(包括输入验证)后再提交的话,通常都必须把submit改成button,即取消其自动提交的行为,否则,将会造成提交两次的效果!
关于submi
t和button
的区别这里转载其他作者的一篇文章供大家查阅:
http://blog.sina.com.cn/s/blog_693d183d0100uolj.html
将数据传给前端
当然,如果我们想将数据传给前端,可以加一条input<input type="text" id="hh">
,然后在js中这样写即可:
$('#btn').click(function () {
$.ajax({
url:'',
type:'post',
//告诉服务器本次数据编码用json格式
contentType:'application/json',
//对数据进行json序列化
data:JSON.stringify({a:1,b:2}), //application/json
success:function (data) {
console.log(data);
$('#hh').val(data)
}
})
})
效果如下:
Ajax传递json数据简介和一个需要注意的小问题的更多相关文章
- boke例子: freermarker:在使用ajax传递json数据的时候多出冒号
boke例子: freermarker:在使用ajax传递json数据的时候多出冒号 json数据是用JSON.stringify()格式化的数据,然后用ajax传递,发现数据多出一个冒号:, 后来度 ...
- Ajax(form表单文件上传、请求头之contentType、Ajax传递json数据、Ajax文件上传)
form表单文件上传 上菜 file_put.html <form action="" method="post" enctype="multi ...
- Struts2中通过Ajax传递json数据
1.导入Struts2所需要的jar包 下载Struts2的jar包时,可以下载struts-2.5.13-min-lib.zip,然后放到项目的/WebContent/WEB-INF/lib路径下s ...
- ajax传递json数据,springmvc后台就收json数据
1.ajax数据的封装 var json = {"token":token};//封装json数据 $.ajax({ url:'', data:JSON.stringify(jso ...
- 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来的Json数据写入数据库表中
摘自:http://blog.csdn.net/mazhaojuan/article/details/8592015 通过js获取前台数据向一般处理程序传递Json数据,并解析Json数据,将前台传来 ...
- python 全栈开发,Day75(Django与Ajax,文件上传,ajax发送json数据,基于Ajax的文件上传,SweetAlert插件)
昨日内容回顾 基于对象的跨表查询 正向查询:关联属性在A表中,所以A对象找关联B表数据,正向查询 反向查询:关联属性在A表中,所以B对象找A对象,反向查询 一对多: 按字段:xx book ----- ...
- AngularJS学习笔记(3)——通过Ajax获取JSON数据
通过Ajax获取JSON数据 以我之前写的与用户交互的动态清单列表为例,使用JSON前todo.html代码如下: <!DOCTYPE html> <html ng-app=&quo ...
- Django与Ajax,文件上传,ajax发送json数据,基于Ajax的文件上传,SweetAlert插件
一.Django与Ajax AJAX准备知识:JSON 什么是 JSON ? JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻 ...
- Jquery 模板插件 jquery.tmpl.js 的使用方法(1):基本语法,绑定,each循环,ajax获取json数据
jquery.tmpl.js 是一个模板js ,主要有2个方法 (1):$.template()方法,将一段script或者是Html编译为模板,例如 $.template('myTemplate' ...
随机推荐
- PAT 1084 Broken Keyboard
1084 Broken Keyboard (20 分) On a broken keyboard, some of the keys are worn out. So when you type ...
- Linux下一个进程可以开多少线程
这个问题,整理了一下网上的资料,结果如下: 一.ulimit -n可以查看一个进程最多可以打开多少文件描述符数: 二.一个进程最多可以产生多少线程,可用如下的方法: 32位linux系统最大内存地址4 ...
- css3的transform-origin配合scale,控制动画,实现各种hover效果
1.底部画线,从左边开始,右边结束 html: <div class="silde-txt">底部划线</div> css: <style>.s ...
- 基于 HTML5 的工业组态高炉炼铁 3D 大屏可视化
前言 在大数据盛行的现在,大屏数据可视化也已经成为了一个热门的话题.大屏可视化可以运用在众多领域中,比如工业互联网.医疗.交通.工业控制等等.将各项重要指标数据以图表.各种图形等形式表现在一个页面上, ...
- okhttp请求文件异常解决方法
微信借口中获取素材的接口返回只是一个缓存的文件流 InputStream, 接口中请求永久图片素材返回的是 InputStream; 接口项目获取到 InputStream 可以直接通过文件流写到文件 ...
- jvm内存溢出问题
Java内存溢出详解 一.常见的Java内存溢出有以下三种: 1. java.lang.OutOfMemoryError: Java heap space ----JVM Heap(堆)溢出 J ...
- Erlang ETS Table
不需要显示用锁,插入和查询时间不仅快而且控制为常量,这就是Erlang的ETS Table. 为什么而设计? Erlang中可以用List表达集合数据,但是如果数据量特别大的话在List中访问元素就会 ...
- Is It Always a Good Idea to Reach Outside Your Comfort Zone?
Learning to stretch outside your comfort zone is critical for learning and growing, advancing in you ...
- lvs三种模式的优缺点对比
电面只回答上来少部分,所以......恶补.总结
- C# 异步通信 网络聊天程序开发 局域网聊天室开发
Prepare 本文将使用一个NuGet公开的组件技术来实现一个局域网聊天程序,利用组件提供的高性能异步网络机制实现,免去了手动编写底层的困扰,易于二次开发,扩展自己的功能. 在Visual Stud ...