在實際項目中,經常遇到字符格式的問題,記下來以便日后方便查看。用到兩個函數:JSON.stringify() 和 JSON.parse()。
使用ajax向后台請求數據,后台給前端返回數據,明明后端腳本寫的是json函數處理后的json格式,但是前端接收數據時,卻時而是object,時而是字符串,令人百思不得其解。具體原因我還不是很清楚。
在數據傳輸過程中,json是以文本,即字符串的形式傳遞的,而JS操作的是JSON對象。所以,JSON對象和JSON字符串之間的相互轉換是關鍵
我的解決思路是:首先直接使用返回的數據,如不能達到預期效果,則用typeof查看返回數據的格式是什么或者console.log打印一下看具體返回的數據是什么,然后在根據需要使用函數進行二次處理。
例如:
JSON字符串:
var str1 = '{ "name": "cxh", "sex": "man" }';
JSON對象:
var str2 = { "name": "cxh", "sex": "man" };
一、JSON字符串轉換為JSON對象
要使用上面的str1,必須使用下面的方法先轉化為JSON對象:
//由JSON字符串轉換為JSON對象
var obj = eval('(' + str + ')');
或者
var obj = str.parseJSON(); //由JSON字符串轉換為JSON對象
或者
var obj = JSON.parse(str); //由JSON字符串轉換為JSON對象
然后,就可以這樣讀取:
Alert(obj.name);
Alert(obj.sex);
特別注意:如果obj本來就是一個JSON對象,那么使用eval()函數轉換后(哪怕是多次轉換)還是JSON對象,但是使用parseJSON()函數處理后會有問題(拋出語法異常)。
二、可以使用toJSONString()或者全局方法JSON.stringify()將JSON對象轉化為JSON字符串。
例如:
var last=obj.toJSONString(); //將JSON對象轉化為JSON字符
或者
var last=JSON.stringify(obj); //將JSON對象轉化為JSON字符
alert(last);
注意:
上面的幾個方法中,除了eval()函數是js自帶的之外,其他的幾個方法都來自json.js包。新版本的 JSON 修改了 API,將 JSON.stringify() 和 JSON.parse() 兩個方法都注入到了 Javascript 的內建對象里面,前者變成了 Object.toJSONString(),而后者變成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()方法,則說明您的json包版本太低。
參考:http://www.jb51.net/article/43136.htm
