当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jquery ajax post提交数据乱码

jquery ajax post提交数据乱码

2018年10月25日  | 移动技术网IT编程  | 我要评论
在用jquery处理html5的应用的时候,一直在firefox下测试都正常,用户用pad访问的时候说有乱码, 自己试验了下果然,后发现chrome和ie内核下都是有此问题,此问题设置了页面属性为u

在用jquery处理html5的应用的时候,一直在firefox下测试都正常,用户用pad访问的时候说有乱码,
自己试验了下果然,后发现chrome和ie内核下都是有此问题,此问题设置了页面属性为utf-8时候,只有firefox是传的charset=utf-8的头文件
chrome和ie都没有指定,所以出现乱码问题.
解决方法:

. 代码如下:


$.ajaxsetup({
  contenttype: "application/x-www-form-urlencoded; charset=utf-8"
});
$.post("test.php", { name: "i5a6", time: "2pm" },
   function(data){
     process(data);
   }, "json");
 


或者使用:

. 代码如下:


$.ajax({
  url:url,
  type:"post",
  data:data,
  contenttype:"application/x-www-form-urlencoded; charset=utf-8",
  datatype:"json",
  success: function(){
    ...
  }
})
 


推荐使用第一种,不过也是根据自己的实际情况看的,有人推荐用 encodeuricomponent 做字符转换
总结一下ajax 提交数据乱码一些经验
为了避免乱码,可以做到以下几步
解决方法
1,保持编码的统一,包括文件编码,编码,网页content-type编码
检查一下<meta http-equiv=”content-type” content=”text/html; charset=utf-8′ />
建议中文都是用utf-8,使用gbk/gb2312有可能会出现乱码
2,使用post来发送而不是get
get方法是会通过链接来传递参数,而且会自动urlencode(编码),而各个编码的方式可能不太一样。使用post可以避免这种情况。
3,通过在js前端escape编码再发送,然后后台解码取得数据
这些可以在网上搜索
4,在全局设定contenttype,指定编码
因为jquery ajax是使用utf-8来编码发送数据的,ie在发送时却没加上charset=utf-8,从而导致乱码(ie默认使用iso-8859-1编码)

. 代码如下:


$.ajaxsetup({
 contenttype: "application/x-www-form-urlencoded; charset=utf-8"
});
 

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网