精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JSON.stringify() 的進(jìn)階用法:解鎖你不曾了解的強(qiáng)大功能

開發(fā) 前端
JSON.stringify() 是 JavaScript 開發(fā)中最常用的方法之一,但大多數(shù)開發(fā)者只停留在基礎(chǔ)的數(shù)據(jù)序列化使用層面。本文將深入探討 JSON.stringify() 的進(jìn)階用法,幫助你寫出更優(yōu)雅、高效的代碼。

JSON.stringify() 是 JavaScript 開發(fā)中最常用的方法之一,但大多數(shù)開發(fā)者只停留在基礎(chǔ)的數(shù)據(jù)序列化使用層面。

實(shí)際上,這個(gè)方法隱藏了許多強(qiáng)大而實(shí)用的功能,能夠解決開發(fā)中的各種實(shí)際問(wèn)題。本文將深入探討 JSON.stringify() 的進(jìn)階用法,幫助你寫出更優(yōu)雅、高效的代碼。

一、基礎(chǔ)回顧:JSON.stringify() 的核心機(jī)制

在深入高級(jí)用法前,我們先明確 JSON.stringify() 的基本行為:

const user = {
name: "web前端開發(fā)官網(wǎng)",
score: 89,
secret: undefined,
  [Symbol('id')]: 123
};

console.log(JSON.stringify(user)); 
// 輸出: '{"name":"web前端開發(fā)官網(wǎng)","score":89}'

關(guān)鍵特性

  • 自動(dòng)忽略 undefined、Symbol 和函數(shù)類型的屬性
  • 只序列化對(duì)象自身的可枚舉屬性
  • 日期對(duì)象會(huì)被轉(zhuǎn)換為 ISO 格式字符串
  • 循環(huán)引用會(huì)拋出錯(cuò)誤

二、選擇性序列化:第二個(gè)參數(shù)的妙用

1. 白名單過(guò)濾:精確控制輸出字段

通過(guò)數(shù)組參數(shù)可以指定需要包含的屬性列表:

const product = {
id: 101,
name: "無(wú)線耳機(jī)",
price: 299,
stock: 50,
manufacturer: "Acme Corp"
};

// 只保留 id 和 name 字段
console.log(JSON.stringify(product, ['id', 'name'])); 
// 輸出: '{"id":101,"name":"無(wú)線耳機(jī)"}'

實(shí)際應(yīng)用場(chǎng)景

  • api 響應(yīng)數(shù)據(jù)瘦身
  • 敏感信息過(guò)濾
  • 減少網(wǎng)絡(luò)傳輸量

2. 轉(zhuǎn)換函數(shù):動(dòng)態(tài)處理每個(gè)屬性

更強(qiáng)大的方式是使用轉(zhuǎn)換函數(shù),它可以遞歸處理每個(gè)屬性:

const employee = {
name: "張三",
salary: 15000,
department: "研發(fā)部",
joinDate: newDate('2020-06-15')
};

const result = JSON.stringify(employee, (key, value) => {
if (key === 'salary') returnundefined; // 隱藏薪資
if (value instanceofDate) return value.toLocaleDateString();
return value;
});

console.log(result);
// 輸出: '{"name":"張三","department":"研發(fā)部","joinDate":"2020/6/15"}'

高級(jí)技巧

  • 實(shí)現(xiàn)自定義的序列化邏輯
  • 數(shù)據(jù)脫敏處理
  • 特殊類型(如 BigInt)的轉(zhuǎn)換

三、美化輸出:第三個(gè)參數(shù)的藝術(shù)

1. 數(shù)字縮進(jìn):標(biāo)準(zhǔn)格式化

const book = {
title: "JavaScript高級(jí)程序設(shè)計(jì)",
author: {
name: "Nicholas C. Zakas",
country: "美國(guó)"
  },
tags: ["前端", "編程", "ES6"]
};

console.log(JSON.stringify(book, null, 2));

輸出效果

{
"title": "JavaScript高級(jí)程序設(shè)計(jì)",
"author": {
"name": "Nicholas C. Zakas",
"country": "美國(guó)"
  },
"tags": [
"前端",
"編程",
"ES6"
  ]
}

2. 自定義縮進(jìn):個(gè)性展示

console.log(JSON.stringify(book, null, '-->'));

輸出效果

{
-->"title": "JavaScript高級(jí)程序設(shè)計(jì)",
-->"author": {
--->"name": "Nicholas C. Zakas",
--->"country": "美國(guó)"
-->},
-->"tags": [
--->"前端",
--->"編程",
--->"ES6"
-->]
}

實(shí)用價(jià)值

  • 調(diào)試時(shí)更易讀的輸出
  • 生成文檔中的示例數(shù)據(jù)
  • 保持團(tuán)隊(duì)代碼風(fēng)格統(tǒng)一

四、深度比較:對(duì)象指紋技術(shù)

1. 對(duì)象比較的痛點(diǎn)

const obj1 = { a: 1, b: 2, 1: "x" };
const obj2 = { b: 2, a: 1, 1: "x" };

console.log(JSON.stringify(obj1) === JSON.stringify(obj2)); // false

2. 鍵序問(wèn)題的本質(zhì)

JavaScript 對(duì)象鍵的順序遵循特定規(guī)則:

  • 數(shù)字鍵:按數(shù)值升序排列(0~232-1)
  • 字符串鍵:按創(chuàng)建順序排列
  • Symbol鍵:不參與序列化

解決方案

functionstableStringify(obj) {
returnJSON.stringify(obj, Object.keys(obj).sort());
}

console.log(stableStringify(obj1) === stableStringify(obj2)); // true

應(yīng)用場(chǎng)景

  • 對(duì)象內(nèi)容比對(duì)
  • 生成唯一緩存鍵
  • 數(shù)據(jù)一致性校驗(yàn)

五、特殊場(chǎng)景處理技巧

1. 處理循環(huán)引用

const circularObj = { a: 1 };
circularObj.self = circularObj;

// 直接序列化會(huì)報(bào)錯(cuò)
// JSON.stringify(circularObj); // TypeError

// 解決方案
const getCircularReplacer = () => {
const seen = new WeakSet();
return (key, value) => {
if (typeofvalue === "object" && value !== null) {
if (seen.has(value)) return'[Circular]';
      seen.add(value);
    }
returnvalue;
  };
};

console.log(JSON.stringify(circularObj, getCircularReplacer()));
// 輸出: {"a":1,"self":"[Circular]"}

2. 自定義 toJSON 方法

classPerson{
constructor(name, age) {
this.name = name;
this.age = age;
  }

  toJSON() {
return {
fullName: `Mr./Ms. ${this.name}`,
birthYear: newDate().getFullYear() - this.age
    };
  }
}

const p = new Person("李四", 30);
console.log(JSON.stringify(p));
// 輸出: {"fullName":"Mr./Ms. 李四","birthYear":1993}

六、性能與安全考量

1. 性能優(yōu)化

// 不好的做法:頻繁序列化大對(duì)象
for (let i = 0; i < 1000; i++) {
localStorage.setItem('data', JSON.stringify(largeObj));
}

// 優(yōu)化方案:只序列化變化部分
let lastState;
functionsavePartial(state) {
const changes = {};
for (const key in state) {
if (state[key] !== lastState?.[key]) {
      changes[key] = state[key];
    }
  }
localStorage.setItem('changes', JSON.stringify(changes));
  lastState = {...state};
}

2. 安全注意事項(xiàng)

// 潛在XSS風(fēng)險(xiǎn)
const userInput = '{"__proto__": {"isAdmin": true}}';
const parsed = JSON.parse(userInput);
Object.assign({}, parsed); // 污染原型鏈

// 安全做法
const safeParse = (json) => {
const parsed = JSON.parse(json);
if (parsed && typeof parsed === 'object') {
Object.setPrototypeOf(parsed, null);
  }
return parsed;
};

七、實(shí)際應(yīng)用案例

1. 深度克隆的局限與改進(jìn)

// 基礎(chǔ)深克隆
functiondeepClone(obj) {
returnJSON.parse(JSON.stringify(obj));
}

// 增強(qiáng)版(處理特殊類型)
functionenhancedDeepClone(obj) {
returnJSON.parse(JSON.stringify(obj, (key, value) => {
if (typeof value === 'bigint') return value.toString() + 'n';
if (value instanceofRegExp) return value.toString();
return value;
  }));
}

2. 數(shù)據(jù)差異比較

functiongetObjectDiff(a, b) {
const stableA = stableStringify(a);
const stableB = stableStringify(b);

if (stableA === stableB) returnnull;

// 實(shí)際項(xiàng)目中可以使用更專業(yè)的diff算法
return {
before: JSON.parse(stableA),
after: JSON.parse(stableB)
  };
}

結(jié)語(yǔ)

JSON.stringify() 遠(yuǎn)不止是一個(gè)簡(jiǎn)單的序列化工具,通過(guò)掌握它的高級(jí)用法,你可以:

  1. 更精準(zhǔn)地控制數(shù)據(jù)輸出
  2. 實(shí)現(xiàn)復(fù)雜對(duì)象的比較和克隆
  3. 提升調(diào)試和日志記錄效率
  4. 處理各種邊界情況和特殊需求

記住這些技巧,它們將在以下場(chǎng)景中發(fā)揮巨大價(jià)值:

  • API 開發(fā)與數(shù)據(jù)處理
  • 狀態(tài)管理與持久化
  • 性能優(yōu)化與調(diào)試
  • 安全數(shù)據(jù)處理

希望本文能幫助你重新認(rèn)識(shí)這個(gè)看似簡(jiǎn)單卻功能強(qiáng)大的方法,在實(shí)際開發(fā)中發(fā)揮它的最大潛力。

責(zé)任編輯:龐桂玉 來(lái)源: web前端開發(fā)
相關(guān)推薦

2021-05-06 05:30:33

JSONstringify()parse()

2021-12-22 09:08:39

JSON.stringJavaScript字符串

2019-06-11 15:25:03

JSON性能前端

2021-12-11 18:59:35

JavascriptJSON應(yīng)用

2020-05-25 14:37:31

JSON.string前端秘密特性

2020-03-29 20:16:09

JavaScript前端技術(shù)

2022-12-05 14:50:53

2024-09-30 11:08:18

JSON局限性數(shù)據(jù)

2024-03-25 00:10:00

JSON后端開發(fā)

2009-09-08 10:35:24

LINQ技術(shù)

2022-08-31 22:50:13

JavaScript函數(shù)JSON

2010-03-04 13:36:55

openSUSE

2025-07-29 09:14:33

2010-08-13 16:10:11

FlexCSS

2009-08-26 18:15:39

ibmdwFlex

2010-08-06 14:23:25

FlexCSS

2009-12-24 11:13:21

2010-03-19 09:34:42

Cisco 2600模

2010-03-26 13:39:28

Python標(biāo)準(zhǔn)庫(kù)

2010-04-27 17:58:17

Oracle 9i
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产盗摄一区二区三区在线| 天堂在线一区二区三区| 香蕉av一区二区三区| 亚洲伊人网站| 日韩在线视频导航| youjizz.com国产| 日韩高清不卡| 一区二区成人在线视频| 免费在线观看一区二区| 国产精品国产三级国产aⅴ| 在线观看视频日韩| 中文字幕一精品亚洲无线一区| 日韩av影视大全| 国产免费不卡| 一区二区三区视频在线观看| 日本成人黄色免费看| 亚洲精品国产av| 日韩激情一二三区| 欧美极品少妇全裸体| 纪美影视在线观看电视版使用方法| 久久99精品久久久野外观看| 日韩欧美国产黄色| 国产 欧美 日本| 午夜在线免费观看视频| 99精品视频一区二区三区| 国产女精品视频网站免费| 日韩av女优在线观看| 97精品国产福利一区二区三区| 亚洲福利视频久久| 特级黄色片视频| 91亚洲精品| 欧美网站在线观看| 999一区二区三区| 黄黄的网站在线观看| 波多野结衣中文字幕一区二区三区 | 欧美视频成人| 日韩一区二区三区xxxx| 日本高清www| 麻豆成人入口| 精品成a人在线观看| 超碰中文字幕在线观看| 久久99久久久精品欧美 | 中文字幕黄色av| 久久亚洲美女| 欧洲亚洲女同hd| www.毛片.com| 国产欧美69| 97成人在线视频| 豆国产97在线 | 亚洲| 一区二区三区四区日韩| 久久五月天色综合| 九九热最新地址| 亚洲精品成人| 久久精品在线播放| 成年人免费视频播放| 日韩久久视频| 久久精品人人做人人爽| 欧美大片xxxx| 午夜国产精品视频| 欧美黑人一区二区三区| 精品无码人妻一区二区三区品| 91av精品| 欧美黄色成人网| 日本三级理论片| 中文日韩欧美| 日本亚洲欧美三级| 涩涩视频在线观看| 久久99在线观看| 亚洲综合中文字幕68页| 丰满人妻一区二区三区免费视频| 国产成人在线视频网址| 国产女主播一区二区| 无码国产色欲xxxx视频| 久久久久久久久岛国免费| 亚洲国产午夜伦理片大全在线观看网站 | 国产真实的和子乱拍在线观看| 一本一本久久| 国产精品女主播| 国产女人高潮毛片| 成人免费高清在线| 欧美一卡2卡3卡4卡无卡免费观看水多多 | 在线成人激情视频| 三级黄色在线观看| 国产精品分类| 国产99在线|中文| 一级黄色大片网站| 国产成人精品1024| 日本电影一区二区三区| av超碰免费在线| 天天操天天综合网| 丰满少妇在线观看| 日韩一二三区在线观看| 亚洲男人7777| 成人在线观看高清| 天堂一区二区在线免费观看| 成人动漫网站在线观看| 天天干免费视频| 国产精品毛片a∨一区二区三区| 欧美激情亚洲天堂| 欧美性片在线观看| 精品三级在线观看| 国产精品18在线| 国产精品日韩久久久| 91精品国产综合久久久久久蜜臀| 男人天堂手机在线观看| 欧美国产激情一区二区三区蜜月| 欧美中日韩在线| 成人午夜在线| 亚洲精品有码在线| 欧美日韩三级在线观看| 免费看黄色91| 久久精品五月婷婷| 18网站在线观看| 欧美视频你懂的| 性久久久久久久久久 | 欧美另类videosbestsex日本| 欧美大电影免费观看| 精品捆绑美女sm三区 | 人人九九精品| 亚洲综合区在线| 国内外成人免费在线视频| 欧美尿孔扩张虐视频| 欧美尺度大的性做爰视频| 在线视频精品免费| 91美女片黄在线观看| 91亚洲精品国产| 亚洲最大的免费视频网站| 亚洲欧美www| 日本一区二区不卡在线| 国产一区福利在线| 一区二区三区不卡在线| 二吊插入一穴一区二区| 日韩精品视频在线播放| 久久网中文字幕| 国产麻豆午夜三级精品| 亚洲午夜在线观看| 天然素人一区二区视频| 亚洲欧美日韩网| 国产精品久久久免费视频| 国产99久久久精品| 超碰10000| 粉嫩一区二区三区在线观看| 自拍偷拍亚洲一区| 丰满人妻一区二区三区四区| 久久精品网站免费观看| av天堂永久资源网| 亚洲人成伊人成综合图片| 91av在线免费观看视频| 日本人妻丰满熟妇久久久久久| 夜夜精品视频一区二区| 无码人妻丰满熟妇区毛片蜜桃精品| 99久久九九| 成人激情视频网| а√天堂资源地址在线下载| 91精选在线观看| 日韩欧美国产成人精品免费| 国精产品一区一区三区mba视频| 先锋影音一区二区三区| 亚洲四虎影院| 最近2019年中文视频免费在线观看| 人妻中文字幕一区二区三区| 国产精品久久午夜| 不卡的一区二区| 亚洲福利一区| 日本不卡在线播放| 亚洲伦理一区二区| 久久久久久国产精品久久| 国产77777| 欧美性生交大片免网| 少妇无套高潮一二三区| 激情深爱一区二区| 白白操在线视频| 欧美亚洲大陆| 国产精品久久久久久久av大片 | 欧美极品第一页| 神马精品久久| 欧美日韩精品欧美日韩精品一 | 日本在线观看www| 日韩一级二级三级| 色网站在线播放| 亚洲国产精品激情在线观看 | 91成人在线精品视频| 8090成年在线看片午夜| 成人18在线| 日韩免费一区二区| 免费看日批视频| 国产精品成人一区二区三区夜夜夜 | 日本高清一区| 精品一区二区三区视频在线播放| 久久久久亚洲精品国产| 国产高清一级毛片在线不卡| 日韩一级黄色片| 国产精品suv一区| 亚洲精选视频免费看| 久久人人妻人人人人妻性色av| 日韩国产精品久久| 国产freexxxx性播放麻豆| av资源久久| 国产一区二区高清视频| 成人av集中营| 97色在线视频| 国产黄色在线免费观看| 亚洲免费视频网站| 亚洲国产精品国自产拍久久| 色噜噜夜夜夜综合网| 国产探花在线免费观看| 久久嫩草精品久久久精品一| 在线a免费观看| 奇米影视一区二区三区小说| 91精品国产成人观看| 日韩电影在线观看中文字幕| 中文在线a天堂| 亚洲一级二级在线| 无码人中文字幕| 久久先锋影音av鲁色资源| 青青草精品在线| 日本网站在线观看一区二区三区| 成人av在线不卡| 日韩久久精品| 欧美一区二视频在线免费观看| 136福利精品导航| 国产欧美日韩丝袜精品一区| 在线男人天堂| 国模叶桐国产精品一区| caopeng在线| 日韩中文视频免费在线观看| 欧美zozo| 亚洲成人动漫在线播放| av中文字幕观看| 777午夜精品免费视频| 波多野结衣激情视频| 福利视频第一区| 日本三级午夜理伦三级三| 一区二区在线免费观看| 69夜色精品国产69乱| 国产精品入口麻豆九色| 亚洲午夜福利在线观看| www.av精品| 少妇一级淫免费观看| 成人综合婷婷国产精品久久蜜臀| 免费不卡av网站| 国产做a爰片久久毛片 | 青娱乐精品视频| 动漫av免费观看| 日韩在线观看一区二区| av免费网站观看| 日韩成人伦理电影在线观看| 色婷婷综合久久久久中文字幕| 老鸭窝91久久精品色噜噜导演| 免费在线观看亚洲视频 | 成人精品视频一区二区| 国产精品综合| 成熟老妇女视频| 首页亚洲欧美制服丝腿| 国产精品第12页| 日韩电影一二三区| 日韩一级理论片| 青青草97国产精品免费观看| the porn av| 国产在线精品视频| 日本成人在线免费| 99re成人在线| 免费看污片的网站| 国产精品久久久久久久久免费丝袜| 国产又粗又黄又猛| 专区另类欧美日韩| 国产在线综合网| 欧美特黄级在线| 亚洲天堂网视频| 日韩一区二区高清| 天堂av在线免费| 国产亚洲精品美女久久久| 麻豆传媒视频在线观看| 九九九热精品免费视频观看网站| tube8在线hd| 国产精品久久久av| 午夜电影一区| 免费看国产精品一二区视频| 色综合天天综合网中文字幕| 日韩精品一区二区免费| 裸体素人女欧美日韩| 午夜天堂在线视频| 99精品视频一区二区三区| 91麻豆制片厂| 亚洲午夜国产一区99re久久| 欧美a视频在线观看| 91精品国产一区二区三区| 五月天福利视频| 日韩在线免费视频| 国产污视频在线播放| 国产欧美精品一区二区| 福利片在线一区二区| 天堂√在线观看一区二区| 国产精品mm| 一起操在线视频| 99精品视频在线观看免费| 男人操女人的视频网站| 欧美性猛交99久久久久99按摩| 国产精品久久久久久久久久久久久久久久 | 欧美激情一区二区三区四区 | 欧美性xxxx极品hd欧美风情| 国产精品视频第一页| 亚洲精品久久在线| 国内精品不卡| 国产精品久久久久久av福利| 国产日韩三级| 欧美aaa在线观看| 久久影院亚洲| 久久久久亚洲AV成人无码国产| 中文字幕一区二区三区av| 国产一级免费视频| 精品欧美黑人一区二区三区| 在线免费观看黄色av| 人人澡人人澡人人看欧美| 51亚洲精品| 在线国产精品网| 日本中文字幕一区| 大黑人交xxx极品hd| 亚洲午夜激情av| 99re只有精品| 久久精品视频99| 日本国产一区| 一本久久a久久精品vr综合| 噜噜噜久久亚洲精品国产品小说| 天天躁日日躁狠狠躁av| 亚洲免费观看高清在线观看| 波多野结衣视频免费观看| 亚洲精品suv精品一区二区| 日韩伦理电影网站| 7777精品久久久大香线蕉小说| 青青草国产免费一区二区下载| 久久成人免费观看| aaa欧美日韩| 免费在线一级片| 欧美精品丝袜久久久中文字幕| 免费一级毛片在线观看| 91av国产在线| 亚洲区小说区图片区qvod按摩| 日韩精品―中文字幕| 成人动漫一区二区三区| 精品在线免费观看视频| 日韩精品一区二| 欧美人与性动交α欧美精品图片| 成人欧美一区二区三区在线湿哒哒| 日韩精品中文字幕第1页| www.这里只有精品| 国产精品人成在线观看免费| 中文字幕1区2区3区| 一本色道久久综合狠狠躁篇怎么玩 | 热草久综合在线| 久久爱www成人| 在线视频日韩一区 | 久久久久久福利| 精品国产91乱码一区二区三区 | 波多野结衣成人在线| 欧美日韩一区二区国产| 精品人妻无码中文字幕18禁| 一区二区三区视频在线看| 粉嫩av一区二区夜夜嗨| 久久人人爽人人爽人人片av高清| 成人av影音| 国产中文字幕免费观看| 久久久精品人体av艺术| 中文字幕乱码人妻二区三区| 色婷婷**av毛片一区| 白嫩亚洲一区二区三区| 免费在线看黄色片| 91香蕉视频污在线| 成年人视频免费| 日韩在线不卡视频| 91国内精品白嫩初高生| 国产91在线视频观看| 国产亚洲精品免费| 国产精品视频a| 久久久亚洲影院| 全球av集中精品导航福利| 搡女人真爽免费午夜网站| 中文字幕一区二区三| 天堂av中文字幕| 国产精品视频免费观看www| **女人18毛片一区二区| 50一60岁老妇女毛片| 91国产免费看| 欧洲在线视频| 日韩av免费电影| 国产精品一区不卡| 69国产精品视频免费观看| 日韩在线观看网址| 精品午夜电影| 超碰在线公开97| 五月天久久比比资源色| 91在线品视觉盛宴免费| 国产伦精品一区二区三毛| 日韩国产欧美在线观看| 久久艹精品视频| 亚洲天堂免费观看| 日韩免费高清视频网站| 国产精品天天av精麻传媒| 一区二区三区在线免费观看| 撸视在线观看免费视频|