javascript
JSON.parse和JSON.stringify方法
JSON.parse()
JSON.parse()方法將json字符串轉(zhuǎn)化為Javascript值或?qū)ο蟆?/span>
語法
JSON.parse(text[,reviver])
參數(shù)
text:要被解析成Javascript值的字符串
reviver:若是一個(gè)函數(shù)則規(guī)定了原始值(text)如何被解析改造,在被返回前。
示例
JSON.parse('{}'); // {} JSON.parse('true'); // true JSON.parse('"foo"'); // "foo" JSON.parse('[1, 5, "false"]'); // [1, 5, "false"] JSON.parse('null'); // null使用reviver函數(shù)(解析值本身以及它所包含的所有屬性,會(huì)按照一定的順序:從最最里層的屬性開始一級級往外,最終到達(dá)頂層,也就是解析值本身分別的去調(diào)用reviver函數(shù))
JSON.parse('{"p":5,"":100}',function(k,v){if(k === "") return v;return v*2; }) 返回:{p:10,"":100}//從這個(gè)例子可以看出遍歷是從內(nèi)往外的。 JSON.parse('{"1":1,"2":2,"3":{"4":4,"5":{"6":6}}}',function(k,v){console.log(k); //輸出當(dāng)前的屬性名,從而得知遍歷順序是從內(nèi)向外的,最后一個(gè)屬性名會(huì)是個(gè)空字符串。return v; //返回原始屬性值,相當(dāng)于沒有傳遞reviver參數(shù)。 }) 返回:1 2 4 6 5 3 ""JSON.stringify()
JSON.stringify() 方法將一個(gè)JavaScript值轉(zhuǎn)換為一個(gè)JSON字符串,如果指定了一個(gè)replacer函數(shù),則可以替換值,或者如果指定了一個(gè)replacer數(shù)組,可選的僅包括指定的屬性.
語法
JSON.stringify(value[,replacer[,space]])
參數(shù)
value:將要序列化成 一個(gè)JSON字符串的值
replacer:如果該參數(shù)是一個(gè)函數(shù),則在序列化過程中,被序列化的值的每個(gè)屬性都會(huì)經(jīng)過該函數(shù)的轉(zhuǎn)換和處理;如果該參數(shù)是一個(gè)數(shù)組,則只有包含在這個(gè)數(shù)組中的屬性名才會(huì)被序列化到最終的 JSON 字符串中;如果該參數(shù)為null或者未提供,則對象所有的屬性都會(huì)被序列化;
space:指定縮進(jìn)用的空白字符串,用于美化輸出(pretty-print);如果參數(shù)是個(gè)數(shù)字,它代表有多少的空格;上限為10。該值若小于1,則意味著沒有空格;如果該參數(shù)為字符串(字符串的前十個(gè)字母),該字符串將被作為空格;如果該參數(shù)沒有提供(或者為null)將沒有空格。
描述
關(guān)于序列化,有下面五點(diǎn)注意事項(xiàng):
1.非數(shù)組對象的屬性不能保證以特定的順序出現(xiàn)在序列化后的字符串中。
2.布爾值、數(shù)字、字符串的包裝對象在序列化過程中會(huì)自動(dòng)轉(zhuǎn)換成對應(yīng)的原始值。
3.undefined、任意的函數(shù)以及 symbol 值,在序列化過程中會(huì)被忽略(出現(xiàn)在非數(shù)組對象的屬性值中時(shí))或者被轉(zhuǎn)換成 null(出現(xiàn)在數(shù)組中時(shí))。
4.所有以 symbol 為屬性鍵的屬性都會(huì)被完全忽略掉,即便 replacer 參數(shù)中強(qiáng)制指定包含了它們。
5.不可枚舉的屬性會(huì)被忽略
replacer參數(shù)
function replacer(key,value){if(typeof value === "string"){return undefined;}return value; } var foo = {foundation: "Mozilla", model: "box", week: 45, transport: "car", month: 7}; var jsonString = JSON.stringify(foo,replacer); 返回:{"week":45,"month":7};//如果replacer是一個(gè)數(shù)組,數(shù)組的值代表將被序列化成JSON字符串的屬性名 JSON.stringify(foo,["model","transport"]); 返回: '{"model":"box","transport":"car"}';總結(jié)
以上是生活随笔為你收集整理的JSON.parse和JSON.stringify方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 原生js来实现对dom元素class的操
- 下一篇: 【vue报错】——listen EADD