json格式的字元串序列化和反序列化的一些高級用法
- 2020 年 3 月 5 日
- 筆記
(1) 僅僅將指定屬性對應的值序列化成字元串:
var filter = {name: 'Jerry', sex: 'male', age: '10'}; var jsonStr4 = JSON.stringify(filter, ['name']); console.log(jsonStr4);
想參與序列化的參數名通過JSON.stringify方法的第二個參數傳入。
上面例子中,只有name欄位及對應的值參與了序列化,輸出如下:

(2) 序列化時,還可以編寫函數,實現自定義序列化邏輯:
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屬性的值通過自定義函數實現,前面加上了前綴。sex屬性被丟棄,age屬性保持不變。
(3) 序列化時增加縮進,讓輸出的字元串更便於閱讀
var obj6 = {name: 'Jerry', sex: 'male', age: '40'}; var jsonStr6 = JSON.stringify(obj6, null, 5); console.log(jsonStr6);
輸出:

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":