技術(shù)頻道導(dǎo)航
HTML/CSS
.NET技術(shù)
IIS技術(shù)
PHP技術(shù)
Js/JQuery
Photoshop
Fireworks
服務(wù)器技術(shù)
操作系統(tǒng)
網(wǎng)站運營

贊助商

分類目錄

贊助商

最新文章

搜索

用JSON.stringify()轉(zhuǎn)換字符串時加過濾函數(shù)只保留數(shù)值項

作者:admin    時間:2022-3-30 19:23:16    瀏覽:

JSON.stringify()轉(zhuǎn)換字符串時,我們可以加一個過濾函數(shù),最終返回的結(jié)果只保留數(shù)值項,或某些特定內(nèi)容的項。

這個功能非常好用,因為我們有時并不需要所有的字符串結(jié)果,我們更想直接得到我們想要的內(nèi)容。

這就是使用了 replacer 方法。

用JSON.stringify()轉(zhuǎn)換字符串時加過濾函數(shù)只保留數(shù)值項

例子(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}

從這個結(jié)果,我們成功只保留了我們想要的內(nèi)容項,把不需要的項移除了。

replacer參數(shù)

replacer 參數(shù)可以是一個函數(shù)或者一個數(shù)組。作為函數(shù),它有兩個參數(shù),鍵(key)和值(value),它們都會被序列化。

在開始時, replacer 函數(shù)會被傳入一個空字符串作為 key 值,代表著要被 stringify 的這個對象。隨后每個對象或數(shù)組上的屬性會被依次傳入。

函數(shù)應(yīng)當返回JSON字符串中的value, 如下所示:

  • 如果返回一個 Number,轉(zhuǎn)換成相應(yīng)的字符串作為屬性值被添加入 JSON 字符串。
  • 如果返回一個 String,該字符串作為屬性值被添加入 JSON 字符串。
  • 如果返回一個 Boolean, "true" 或者 "false" 作為屬性值被添加入 JSON 字符串。
  • 如果返回任何其他對象,該對象遞歸地序列化成 JSON 字符串,對每個屬性調(diào)用 replacer 方法。除非該對象是一個函數(shù),這種情況將不會被序列化成 JSON 字符串。
  • 如果返回 undefined,該屬性值不會在 JSON 字符串中輸出。

注意:不能用 replacer 方法,從數(shù)組中移除值(values),如若返回 undefined 或者一個函數(shù),將會被 null 取代。

例子(array)

如果 replacer 是一個數(shù)組,數(shù)組的值代表將被序列化成 JSON 字符串的屬性名。

JSON.stringify(foo, ['week', 'month']);
// '{"week":45,"month":7}', 只保留 “week” 和 “month” 屬性值。

您可能對以下文章也感興趣

標簽: JSON  JSON.stringify  
x
  • 站長推薦
/* 左側(cè)顯示文章內(nèi)容目錄 */