玩转web之json---将表单通过serialize()方法获取的值转成json

Posted wzzkaifa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了玩转web之json---将表单通过serialize()方法获取的值转成json相关的知识,希望对你有一定的参考价值。

form表单有一个serialize()方法。能够序列化表单的值,可是jquery提供的这种方法会把数据序列化为类似以下的形式:

a=1&b=2&c=3&d=4

jquery并没有提供将表单数据序列化为json的方法。所以须要我们自己封装一下。以下给出代码和測试例子,先写一个js文件:

$.ajaxSetup({
    contentType: "application/x-www-form-urlencoded; charset=utf-8"
});
var DataDeal = {
//将从form中通过$(‘#form‘).serialize()获取的值转成json
		   formToJson: function (data) {
			   data=data.replace(/&/g,"\",\"");
               data=data.replace(/=/g,"\":\"");
               data="{\""+data+"\"}";
               return data;
		    },
};

用法:先在页面导入上面的js文件,然后

        var data=$(‘#addf‘).serialize();//获取值
        data= decodeURIComponent(data,true);//防止中文乱码
        var json=DataDeal.formToJson(data);//转化为json





以上是关于玩转web之json---将表单通过serialize()方法获取的值转成json的主要内容,如果未能解决你的问题,请参考以下文章

带你玩转web开发之四 -如何用JS做登录注册页面校验

从零玩转JavaWeb系列7web服务器-----表单的提交

玩转web表单网页快速开发(❤建议收藏❤)

Flask之模板web表单

神奇的Content-Type——在JSON中玩转XXE攻击

JavaScript之form表单的序列化和json化[form.js]