js中 json對象與json字符串相互轉換的幾種方式


今天在工作中,需要在前端 將需要提交至服務器的數據 組裝成json對象,然后轉化為字符串,提交至后端。

nodes = $('#PmPbsSelect_tree').tree('getChecked');
var data=[];
for(var i=0;i<nodes.length;i++){
    if(!isParentCheck(nodes[i],nodes)){
        data.push({"id":nodes[i].id,"pid":node.id});
    }else{
        data.push({"id":nodes[i].id,"pid":null});
        }
}
//將json對象轉化為字符串
dataStr=JSON.stringify(data);
//ajax提交請求 if (nodes) { $.ajax({ url:ctx+"/PmWbs/savePmWbsByModel", type:"POST", data:{"dataStr":dataStr, "projectId":pmProjectSelect.combobox('getValue')}, success:function(data){ basetree.tree('reload'); }, error:function(){ alert("請求失敗"); }, dataType:"json" }); return true; } else { alertInfo("請選擇項目"); return false; }

 

以下總結js中 json對象與json字符串相互轉換的幾種方式:

一、JSON對象轉化為JSON字符串

1.使用JSON.stringify()方法進行轉換

該方法不支持較老版本的IE瀏覽器,比如:ie8(兼容模式)、ie7、ie6。

var jsonStr = JSON.stringify(jsonObj);
alert(jsonStr);

 

 

二、JSON字符串轉化為JSON對象

1.使用eval()函數進行轉換

使用 eval() 轉換時需要在 json 字符外包裹一對小括號。

ie8(兼容模式)、ie7、ie6 不要使用此方法。

var jsonObj = eval('(' + jsonStr + ')');
alert(jsonObj[0]["key"]);

2.使用JSON.parse()方法進行轉換

ie8(兼容模式)、ie7、ie6 不要使用此方法。

var jsonObj = JSON.parse(jsonStr);

3.使用jQuery進行轉換

如果我們項目中有使用 jQuery,那么直接使用 $.parseJSON() 方法即可,而且可以確保各個瀏覽器的兼容性。

var jsonObj = $.parseJSON(jsonStr);

 

以后有需要再進行擴充


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM