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

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;ivar 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);
                }
        });

    }

表单序列化

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

你可能感兴趣的:(Web前端,Java)