json格式的字符串序列化和反序列化的高級用法是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)是一家專業(yè)提供羅江企業(yè)網(wǎng)站建設(shè),專注與做網(wǎng)站、成都網(wǎng)站建設(shè)、H5技術(shù)、小程序制作等業(yè)務(wù)。10年已為羅江眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。
(1) 僅僅將指定屬性對應(yīng)的值序列化成字符串:
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字段及對應(yīng)的值參與了序列化,輸出如下:
(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) 序列化時增加縮進(jìn),讓輸出的字符串更便于閱讀
var obj6 = {name: 'Jerry', sex: 'male', age: '40'}; var jsonStr6 = JSON.stringify(obj6, null, 5); console.log(jsonStr6);
輸出:
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。