Json对象与Json字符串互转(4种转换方式)表单提交和表单序列化

来源:互联网 发布:项羽跟虞姬 知乎 编辑:程序博客网 时间:2024/05/19 11:50

Json字符与Json对象的相互转换方式有很多,接下来将为大家一一介绍下
1>jQuery插件支持的转换方式:

$.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 

2>浏览器支持的转换方式(Firefox,chrome,opera,safari,ie9,ie8)等浏览器:

JSON.parse(jsonstr); //可以将json字符串转换成json对象 JSON.stringify(jsonobj); //可以将json对象转换成json对符串 

注:ie8(兼容模式),ie7和ie6没有JSON对象,推荐采用JSON官方的方式,引入json.js。

3>Javascript支持的转换方式:
eval(‘(’ + jsonstr + ‘)’); //可以将json字符串转换成json对象,注意需要在json字符外包裹一对小括号
注:ie8(兼容模式),ie7和ie6也可以使用eval()将字符串转为JSON对象,但不推荐这些方式,这种方式不安全eval会执行json串中的表达式。

4>JSON官方的转换方式:
http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;
可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。

—表单提交实例—

    //添加、编辑 提交    function submitDet() {    //JSON.parse(jsonstr); 可以将json字符串转换成json对象     //JSON.stringify(jsonobj); 可以将json对象转换成json对符串     var jsonForm = $("#detForm").serializeArray();    //把表单中对象name value赋值到json对象中。    var json = {};    for(var i=0;i<jsonForm.length;i++){        var jsonName = jsonForm[i].name;        var jsonValue = jsonForm[i].value;        json[jsonName] = jsonValue;    }    var jsonStr = JSON.stringify(json);        $.ajax({                type:"POST",                url:"<%=basePath %>tysh/tyshModify.do",                 data:{                    'jsonStr': jsonStr                },                async:true,                cache:false,                success:function(msg){                    alert(msg);                }        });    }

表单序列化

这里写图片描述

0 0
原创粉丝点击