一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - json - json.stringify()與json.parse()的區別以及用處

json.stringify()與json.parse()的區別以及用處

2022-01-06 15:31Adelamm json

這篇文章主要介紹了json.stringify()與json.parse()的區別以及用處,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一、JSON.stringify()和JSON.parse() 區別

我們都用過JSON.stringify()和JSON.parse() ,從名字上就能知道
JSON.stringify()的作用是將JavaScript對象轉換為JSON 字符串
JSON.parse()可以將JSON字符串轉為一個對象。

通俗易懂版:

  • JSON.stringify() 將對象a轉化成字符串s;
  • JSON.parse() 將字符串s轉化成對象a;

簡單點說,它們的作用是相對的,我用JSON.stringify()將對象a變成了字符串c,那么我就可以用JSON.parse()將字符串c還原成對象a。

?
1
2
3
4
5
6
7
let arr = [1,2,3];
JSON.stringify(arr);//'[1,2,3]'
typeof JSON.stringify(arr);//string
 
let string = '[1,2,3]';
console.log(JSON.parse(string))//[1,2,3]
console.log(typeof JSON.parse(string))//object

在使用JSON.parse()需要注意一點,由于此方法是將JSON字符串轉換成對象,所以你的字符串必須符合JSON格式,即鍵值都必須使用雙引號包裹:

?
1
2
3
4
let a = '["1","2"]';
let b = "['1','2']";
console.log(JSON.parse(a));// Array [1,2]
console.log(JSON.parse(b));// 報錯

二、JSON.stringify()妙用

1.判斷數組是否包含某對象,或者判斷對象是否相等。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
//判斷數組是否包含某對象
let data = [
  {name:'掘金'},
  {name:'css學習'},
  {name:'js學習'},
  ],
  val = {name:'掘金'};
JSON.stringify(data).indexOf(JSON.stringify(val)) !== -1; // true
 
//判斷兩數組/對象是否相等
let a = [1,2,3],
  b = [1,2,3];
JSON.stringify(a) === JSON.stringify(b);//true

2.讓localStorage/sessionStorage可以存儲對象。

localStorage/sessionStorage默認只能存儲字符串,而實際開發中,我們往往需要存儲的數據多為對象類型,那么這里我們就可以在存儲時利用json.stringify()將對象轉為字符串,而在取緩存時,只需配合json.parse()轉回對象即可。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
//存
function setLocalStorage(key,val){
  window.localStorage.setItem(key,JSON.stringify(val));
};
//取
function getLocalStorage(key){
  let val = JSON.parse(window.localStorage.getItem(key));
 window.localStorage.removeItem(key)
  return val;
};
//測試
let data = [
  {name:'掘金'},
  {name:'css學習'},
  {name:'js學習'},
  ];
setLocalStorage('STORAGEDATE',data);
let a = getLocalStorage('STORAGEDATE');

3.實現對象深拷貝

實際開發中,如果怕影響原數據,我們常深拷貝出一份數據做任意操作,其實使用JSON.stringify()與JSON.parse()來實現深拷貝是很不錯的選擇。

?
1
2
3
4
5
6
7
8
9
10
11
//深拷貝
function deepClone(data) {
  let _data = JSON.stringify(data),
    dataClone = JSON.parse(_data);
  return dataClone;
};
//測試
let arr = [1,2,3],
  _arr = deepClone(arr);
arr[0] = 2;
console.log(arr,_arr)//[2,2,3] [1,2,3]

到此這篇關于json.stringify()與json.parse()的區別以及用處的文章就介紹到這了,更多相關json.stringify()與json.parse()內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://juejin.cn/post/6920883049957687303

延伸 · 閱讀

精彩推薦
  • jsonjson.stringify()與json.parse()的區別以及用處

    json.stringify()與json.parse()的區別以及用處

    這篇文章主要介紹了json.stringify()與json.parse()的區別以及用處,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    Adelamm4822022-01-06
  • json用 JSON 處理緩存

    用 JSON 處理緩存

    使用 JSON(即 JavaScript Object Notation),將以一種特定的字符串形式來表示 JavaScript 對象。如果將具有這樣一種形式的字符串賦給任意一個 JavaScript 變量,該...

    JSON教程網8982022-01-03
  • json詳解如何解決使用JSON.stringify時遇到的循環引用問題

    詳解如何解決使用JSON.stringify時遇到的循環引用問題

    這篇文章主要介紹了詳解如何解決使用JSON.stringify時遇到的循環引用問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習...

    汪子熙10972022-02-20
  • json看了就知道什么是JSON

    看了就知道什么是JSON

    JSON(Javascript Object Notation) 是一種輕量級的數據交換格式。易于人閱讀和編寫。同時也易于機器解析和生成。它基于Javascript Programming Language, Standard ECMA-262 ...

    JSON教程網6042022-01-03
  • json厲害了,ECMAScript 新提案:JSON模塊

    厲害了,ECMAScript 新提案:JSON模塊

    第三階段的一個名為JSON模塊的新提議,提出了一種將JSON導入到ES模塊的方法。現在,我們來看看JSON模塊是如何工作的。...

    大遷世界11342021-12-27
  • json告訴大家什么是JSON

    告訴大家什么是JSON

    JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。易于人閱讀和編寫。同時也易于機器解析和生成。...

    json教程網6622022-01-03
  • json使Ext的Template可以解析二層的json數據的方法

    使Ext的Template可以解析二層的json數據的方法

    使Ext的Template可以解析二層的json數據的方法...

    json教程網4982022-01-03
  • jsonJSON學習筆記

    JSON學習筆記

    JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式,易于閱讀和編寫,同時也易于機器解析和生成。它基于ECMA262語言規范(1999-12第三版)中JavaScript編...

    JSON教程網3642022-01-03
主站蜘蛛池模板: 国产精品久久免费 | 国产在线步兵一区二区三区 | 日本加勒比在线精品视频 | 免费特黄一级欧美大片在线看 | 给我免费观看的视频在线播放 | 久久电影院久久国产 | 亚洲娇小videos | 日本大尺度激情做爰叫床 | 高清不卡日本v在线二区 | 美女下面被cao出水 美女污视频 | 好逼365| 久久婷婷五月综合色丁香 | 亚洲精品在看在线观看 | 亚洲AV国产福利精品在现观看 | jzzjlzz亚洲乱熟在线播放 | 星空无限传媒xk8027穆娜 | 成人福利影院 | 欧美一级在线 | 日韩aⅴ在线观看 | 毛片大全高清免费 | 单亲乱l仑在线观看免费观看 | 亚洲网色| 免费精品一区二区三区在线观看 | 亚洲AV蜜桃永久无码精品无码网 | hezyo加勒比一区二区三区 | 波多野结衣作品在线观看 | 国产一区二区在线观看视频 | 国色天香 社区视频 | 四虎永久网址在线观看 | 99rv精品视频在线播放 | tk白嫩玉足脚心vk | 国产性片在线观看 | 国产成人一区二区三区影院免费 | 午夜福利在线观看6080 | 婷婷激情综合五月天 | 国产射频放大器 | 91进入蜜桃臀在线播放 | 996免费视频国产在线播放 | 欧美黑人性猛交╳xx╳动态图 | 欧美怡红院视频一区二区三区 | 婷婷在线观看香蕉五月天 |