json格式的字符串序列化和反序列化的高級用法是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
(1) 僅僅將指定屬性對應的值序列化成字符串:
var filter = {name: 'Jerry', sex: 'male', age: '10'}; var jsonStr4 = JSON.stringify(filter, ['name']); console.log(jsonStr4);
想?yún)⑴c序列化的參數(shù)名通過JSON.stringify方法的第二個參數(shù)傳入。
上面例子中,只有name字段及對應的值參與了序列化,輸出如下:
(2) 序列化時,還可以編寫函數(shù),實現(xiàn)自定義序列化邏輯:
var obj = {name: 'Jerry', sex: 'male', age: '40'}; var jsonStr5 = JSON.stringify(obj, function(key, value) { if(key === 'name') { return 'my name is: ' + value; } else if( key === 'sex'){ // do not return, discard this attribute } else return value; });
輸出:
name屬性的值通過自定義函數(shù)實現(xiàn),前面加上了前綴。sex屬性被丟棄,age屬性保持不變。
(3) 序列化時增加縮進,讓輸出的字符串更便于閱讀
var obj6 = {name: 'Jerry', sex: 'male', age: '40'}; var jsonStr6 = JSON.stringify(obj6, null, 5); console.log(jsonStr6);
輸出:
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)-成都網(wǎng)站建設公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。