jquery接收不到数据的解决办法:1、设置“contenttype:application/x-www-form-urlencoded”;2、检查post和get语句即可。
本文操作环境:windows7系统、jquery3.2.1、dell g3电脑。
jquery接收不到数据怎么办?jquery ajax从后台取不到数据 ?
ajax post data 获取不到数据,注意 content-type的设置 、post/get
关于 jquery data 传递数据。网上各种获取不到数据,乱码之类的。
好吧今天我也遇到了,网上一查各种纠结。乱码不管先看获取不到数据。
因为之前一直用jquery ajax get的方式传递参数, 默认没有设置过 contenttype 的值。
1: var skip = 49; //number of skipped row 2: var take = 14; // 3: function load(skip, take) { 4: $('#ppostsloader').html('<img src="progressbar/ajax-loader.gif">'); 5: //send a query to server side to present new content 6: $.ajax({ 7: type: "get", 8: url: "ajaximage.ashx", 9: data: { skip: skip, take: take }, 10: //contenttype: "application/json; charset=utf-8",//(可以) 11: //contenttype: "text/xml",//(可以) 12: //contenttype:"application/x-www-form-urlencoded",//(可以) 13: //datatype: "string", 14: success: function (data) { 15: if (data != "") { 16: $('.thumb').append(data); 17: } 18: $('#ppostsloader').empty(); 19: } 20: }) 21: };
chrome下,没有设置contenttype的值,好,我们来看jquery中的默认情况:
默认参数通过url参数传递,请求的内容类型:application/x-www-form-urlencoded
一般处理文件获取参数内容:
int skip = convert.toint32(context.request["skip"]); 2: int take = convert.toint32(context.request["take"]);
毫无压力,因为我一直都是这么干的,没有任何问题。好了,来换一下请求的内容类型:
1: //contenttype: "application/json; charset=utf-8",//(可以) 2: //contenttype: "text/xml",//(可以)
也都可以,参数获取正常。
这也就是我们说的get方式,参数是跟在url后边,与content-type无关。
可是今天要用post方式了有木有。
1: $.ajax({ 2: type: "post",
chrome下,没有设置contenttype的值,来看默认情况:
data数据由from表单提交,请求的内容类型:application/x-www-form-urlencoded,
好了,默认情况下一般处理文件获取参数也可以。
可是,但是 我最开始设置的是 contenttype: "application/json; charset=utf-8",看图:
request paload 是什么???
调试一下,看我们的from里边,没有内容:
经测试:
1: //contenttype: "application/json; charset=utf-8",//(不可以) 2: //contenttype: "text/xml",//(不可以) 3: contenttype:"application/x-www-form-urlencoded",//(可以)
总结一下吧:本来get/post方式都是知道的,但注意,contenttype与传递数据匹配(本文data)。
做过模拟登录、模拟提交数据的同学肯定都很清楚了。
推荐学习:《jquery视频教程》
以上就是jquery接收不到数据怎么办的详细内容。