|
|
|
|
|
用JSON.stringify()
轉(zhuǎn)換字符串時(shí),我們可以加一個(gè)過(guò)濾函數(shù),最終返回的結(jié)果只保留數(shù)值項(xiàng),或某些特定內(nèi)容的項(xiàng)。
這個(gè)功能非常好用,因?yàn)槲覀冇袝r(shí)并不需要所有的字符串結(jié)果,我們更想直接得到我們想要的內(nèi)容。
這就是使用了 replacer
方法。
例子(function)
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);
結(jié)果為
{"week":45,"month":7}
從這個(gè)結(jié)果,我們成功只保留了我們想要的內(nèi)容項(xiàng),把不需要的項(xiàng)移除了。
replacer參數(shù)
replacer
參數(shù)可以是一個(gè)函數(shù)或者一個(gè)數(shù)組。作為函數(shù),它有兩個(gè)參數(shù),鍵(key)和值(value),它們都會(huì)被序列化。
在開(kāi)始時(shí), replacer
函數(shù)會(huì)被傳入一個(gè)空字符串作為 key 值,代表著要被 stringify
的這個(gè)對(duì)象。隨后每個(gè)對(duì)象或數(shù)組上的屬性會(huì)被依次傳入。
函數(shù)應(yīng)當(dāng)返回JSON字符串中的value, 如下所示:
replacer
方法。除非該對(duì)象是一個(gè)函數(shù),這種情況將不會(huì)被序列化成 JSON 字符串。注意:不能用 replacer
方法,從數(shù)組中移除值(values),如若返回 undefined 或者一個(gè)函數(shù),將會(huì)被 null 取代。
例子(array)
如果 replacer
是一個(gè)數(shù)組,數(shù)組的值代表將被序列化成 JSON 字符串的屬性名。
JSON.stringify(foo, ['week', 'month']);
// '{"week":45,"month":7}', 只保留 “week” 和 “month” 屬性值。