form 表单使用.serialize()序列化后会出现中文乱码的问题
原因:
.serialize()自动调用了encodeURIComponent方法将数据编码了
解决方法:
解决方法:
调用decodeURIComponent(XXX,true);将数据解码
例如:
例如:
var information=$("#inforForm").serialize(),
informationDe= decodeURIComponent(information,true), //解码
informationEn= encodeURI(encodeURI(informationDe)); //再次编码
后台
String paramsTrans = new String(params.getBytes("ISO-8859-1"),"UTF-8");
params = java.net.URLDecoder.decode(paramsTrans , "UTF-8");
页面端发出的数据作两次encodeURI,这个做的好处在于,不管浏览器用户在页面来设置编码,服务器所采用的编码来做一次URLencode转换成UTF-8
.serialize()值转化为json格式
.serialize()序列化之后的传值是
a=1&b=2&c=3
这种样式,实际使用中还是json比较方便
//转化为json
function strToObj(str){
str = str.replace(/&/g,"','");
str = str.replace(/=/g,"':'");
str = "({'"+str +"'})";
obj = eval(str);
return obj;
}
ajax取值后自动赋值给span
function inquireInfor(){
var information=$("#inforForm").serialize(),
//解码
informationDe = decodeURIComponent(information,true),
informationDeJson=strToObj(informationDe),
inforSpan=$("#inforDiv span"); var len = inforSpan.size();//获取span标签的个数
var arr = [];
var result=eval(informationDeJson);
for(var index = ; index < len-; index++){//创建一个数字数组
arr[index] = index;
}
$.each(arr, function(i){//循环得到不同的id的值
var idValue = inforSpan.eq(i).attr("id");
if(idValue != ''){
$('span'+'#'+idValue).html(result[idValue]); //根据ID从传值的json里面取值
}
});
}