亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JSON與js對象序列化實例詳解

2019-11-19 17:07:57
字體:
來源:轉載
供稿:網友

本文實例講述了JSON與js對象序列化。分享給大家供大家參考,具體如下:

JavaScript對象表示法(JavaScript Object Notation,簡稱JSON)是一種輕量級的數據交換格式,它基于js字面量表示法,是js的一個子集。雖然是一個js的子集但是他與語言無關,它可以用于在現在所有的編程語言編寫的應用程序之間進行數據交換。是一種文本格式,比較容易讀寫。

JSON是一個容納“名/值”對的無序集合,名字可以是任意字符串,值可以使任意的JSON類型的值。大多數編程語言都有被映射為JSON的數據類型,比 如對象(object),字典(dictionary),哈希表(hash map),關聯數組(associative array)等。

JSON有六種類型的值:對象,數組,字符串,數字,布爾值和特殊值null。

console.log(JSON.parse('5')); // 5console.log(JSON.parse(5)); // 5console.log(JSON.parse('true')); // trueconsole.log(JSON.parse(true)); // trueconsole.log(JSON.parse('"hello"')); // "hello"console.log(JSON.parse("hello")); // 報錯 因為hello不是JSON字符串console.log(JSON.parse('null')); // nullconsole.log(JSON.parse(null)); // nullconsole.log(JSON.parse(undefined)); // 報錯 因為JSON不能表示undefined換用null代替

JSON的結構

JSON具有兩種結構:對象,數組

對象結構以”{”大括號開始,以”}”大括號結束。中間部分由0或多個以”,”分隔的”key(關鍵字)/value(值)”對構成,關鍵字字符串和值之間以”:”分隔,語法結構如代碼。

{  key1:value1,  key2:value2,  ...}

例如:

{  "name": "hum",  "age": 26,  "sex": 1,  "love": [    "swing",    "jump"  ],  "birthday": "1988-01-12"}

NOTE:

在js中表示JSON字符串時最好在外面加上單引號。

如下:

復制代碼 代碼如下:
console.log(JSON.parse('{"num":5,"stop":true,"str":"hello","empty":null}'));// object{num:5,stop:true,str:"hello",empty: null}

與js對象字面量相比,JSON對象沒有變量聲明也沒有末尾的分號。
數組結構以”[”開始,”]”結束。中間由0或多個以”,”分隔的值列表組成,語法結構如代碼。

[  {    key1:value1,    key2:value2,   ...  }]

例如:

[ {   "Id": 7,  "Mentions": [    {     "Id": 5,     "StatusId": 34,     "CreatedDateTime":"http://Date(1310051914617+0100)//",     "Text":"Text",     "UserName":"Username",    "UserLocation":"UK",    "UserLanguage":"en-GB",     "IsCheckIn":"true"   }  ],   "Checkins": 0,   "HereNow": 0,   "TimeStamp":"http://Date(1310051914639+0100)//",   "Venue": {    "Id": 7,    "FoursquareId":"cacbf3bd-f0aa-403d-9f9b-2056b4985ba1",    "Name":"Venue Name"   }  },  {    "name":"hahahhahah",    "port":[     {       "port": 8080,       "protocol":"HTTP",       "IP":"123.12.06.456"     }    ]  }]

JSON數組采用的是javascript數組字面量的形式。

JSON的解析與序列化

js的JSON的解析與序列化與AS3是相同的。我們常用的也就是JSON對象(ECMAScript 5中添加的, 早期JSON解析基本都使用javascript的eval()函數。但是eval有一些性能和安全上的缺點,ECMAScript對解析JSON對象進 行了規范,定義了全局對象JSON,支持的瀏覽器有標準瀏覽器和IE8+。對于不支持的瀏覽器可以引入json2.js文件。)的stringify與parse這兩個方法。

接下來我們來一一說明。

JSON.stringify

JSON.stringify()將javascript對象序列化為JSON格式的字符串
JSON.stringify(ob,filter,indent)包含三個參數,通常我們在使用的時候只帶第一個參數,來返回字符串。

ob:要轉化成JSON字符串的對象,數組,原始值。
filter:是一個可選的參數,通常是一個函數,用來在字符串化前對值做一些替換。也可以是一個數組,包含哪些需要字符串化的屬性名。就是用來過濾的。
indent:也是一個可選參數,在需要輸出格式化的可閱讀的代碼時,使用indent參數來指定用來縮進的字符串或空格。如果省略該參數,返回的字符串將不帶任何的額外的空格,這樣輸出的值很難閱讀。就是用來格式化的。

下面是幾個對應的例子:

首先是第二個參數是數組過濾器的時候:

var oJson = { name: 'hum', age: 20, sex: 1};console.log(JSON.stringify(oJson, ['age', 'sex'])); // {"age":20,"sex":1}

如果第二個參數是字符串的時候,該數組會作為對象的屬性名,屬性名不在這個數組中的任何對象的屬性在序列化的時候都會被忽略掉。此外,返回的字符串中的屬性的順序,會與該數組中的屬性名一致。

函數過濾器的時候:

var oJson = { name: 'hum', age: 26, sex: 1, love: ['swing', 'jump']};  console.log(JSON.stringify(oJson, function(k, v){    switch (k){      case 'age':        return v > 20 ? '成年': '未成年';      case 'love':        return v.join(',');      case 'sex':        return undefined;      default :        return v;    }  })); // {"name":"hum","age":"成年","love":"swing,jump"}

如果該參數是函數,則它是一個替換函數,該函數會在每一個需要字符串化的對象上調用。這個函數的第一個參數是該對象中的屬性名或數組的序號,第二個則是值本身。函數的返回值會替換掉需要字符串化的值,如果函數返回undefined或沒有任何的返回值,則會在字符串化的時候忽略這個值。

stringify的第三個參數的實例:

var oJson = { name: 'hum', age: 26, sex: 1, love: ['swing', 'jump']};  console.log(JSON.stringify(oJson, null, 4));  /*   {     "name": "hum",     "age": 26,     "sex": 1,     "love": [       "swing",       "jump"     ]   }  */

通常這個方法的返回值是一個不帶任何空格或換行符的給機器閱讀的字符串,如果想輸出更易于閱讀的代碼,就需要設置第三個參數了。

再來看一個例子:

var oJson = { name: 'hum', age: 26, sex: 1, love: ['swing', 'jump']};  console.log(JSON.stringify(oJson, null, '--'));  /*   {   --"name": "hum",   --"age": 26,   --"sex": 1,   --"love": [   ----"swing",   ----"jump"   --]   }  */

這樣就很容易理解了。。。

JSON.parse

JSON.parse用來解析json格式的字符串(返回一個對象,數組或原始值)

JSON.parse(s,reviver)包含兩個方法.

s:要解析的字符串
reviver:用來轉換解析值得可選函數

我們通常使用只使用第一個參數,可選參數reviver,主要是在返回解析值之前,對其進行過濾或后期處理。reviver函數會在從s中解析的每個原始值調用一次。調用reviver函數是帶有兩個參數,第一個屬性名(對象的屬性名或是轉換成字符串的數組序號),第二個參數是對象的屬性或是數組的元素值。reviver函數會作為包含原始值的對象/數組的方法來調用。reviver函數的返回值會成為屬性的新值,如果reviver返回第二個參數,則屬性不變。如果reviver返回undefined或不凡會任何值,則會從對象或是數組中刪除屬性。
下面是一個實例:

var oJson = { name: 'hum', age: 26, sex: 1, love: ['swing', 'jump'], birthday: '1988-01-12'};  var sJson = JSON.stringify(oJson);  console.log(sJson);//{"name":"hum","age":26,"sex":1,"love":["swing","jump"],"birthday":"1988-01-12"}  console.log(JSON.parse(sJson));  console.log(JSON.parse(sJson, function (k, v) {    if(k == 'birthday'){ // 返回日期對象      return new Date(v);    }else if(k == 'sex'){ // sex不在了      return undefined;    }else{      return v;    }  }));

PS:關于json操作,這里再為大家推薦幾款比較實用的json在線工具供大家參考使用:

在線JSON代碼檢驗、檢驗、美化、格式化工具:
http://tools.VeVB.COm/code/json

JSON在線格式化工具:
http://tools.VeVB.COm/code/jsonformat

在線XML/JSON互相轉換工具:
http://tools.VeVB.COm/code/xmljson

json代碼在線格式化/美化/壓縮/編輯/轉換工具:
http://tools.VeVB.COm/code/jsoncodeformat

在線json壓縮/轉義工具:
http://tools.VeVB.COm/code/json_yasuo_trans

C語言風格/HTML/CSS/json代碼格式化美化工具:
http://tools.VeVB.COm/code/ccode_html_css_json

更多關于JavaScript相關內容可查看本站專題:《JavaScript中json操作技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美视频在线看| 91精品久久久久久久久久久久久| 国产精品偷伦免费视频观看的| 欧洲亚洲女同hd| 国产91在线视频| 亚洲综合成人婷婷小说| 欧美在线激情网| 九九精品在线观看| 久久琪琪电影院| 国产亚洲精品va在线观看| 欧美亚洲视频在线观看| 亚洲人成在线观看网站高清| 97视频免费在线看| 亚洲网站在线观看| 乱亲女秽乱长久久久| 国产精品欧美亚洲777777| 久久精品电影网站| 懂色av中文一区二区三区天美| 久久久久久中文字幕| 91精品国产亚洲| 欧美国产日产韩国视频| 国产97在线亚洲| 欧美一级高清免费| 欧美巨大黑人极品精男| 成人疯狂猛交xxx| 久久精品国产2020观看福利| 国产日韩精品在线观看| 精品亚洲一区二区三区在线播放| 欧美日韩国产综合视频在线观看中文| 欧美黑人一级爽快片淫片高清| 国模私拍视频一区| 国产噜噜噜噜噜久久久久久久久| 91超碰中文字幕久久精品| 亚洲最新在线视频| 精品综合久久久久久97| 国产免费亚洲高清| 高清日韩电视剧大全免费播放在线观看| 日本亚洲精品在线观看| 中文字幕亚洲情99在线| 91免费版网站入口| 亚洲精品大尺度| 国产精品电影久久久久电影网| 国产+人+亚洲| 日韩av网址在线| 色噜噜国产精品视频一区二区| 色偷偷噜噜噜亚洲男人| 国产精品一二三在线| 欧美激情xxxx| 久久精品亚洲精品| 中文字幕亚洲一区二区三区五十路| 亚洲自拍小视频| 精品亚洲一区二区| 亚洲国产欧美在线成人app| 亚洲欧美在线一区二区| 亚洲激情视频网站| 欧美成人网在线| 自拍偷拍亚洲区| 久久精品青青大伊人av| 亚洲精品中文字幕av| 国产精品第1页| 97视频在线观看视频免费视频| 青青草99啪国产免费| 欧美一区二区色| 国产一区二区三区三区在线观看| 亚洲欧美日韩精品| 中文字幕日韩欧美精品在线观看| 国产综合久久久久| 午夜精品久久久久久久男人的天堂| 中文字幕精品一区二区精品| 成人av在线网址| 日韩中文字在线| 人人做人人澡人人爽欧美| 欧美高清一级大片| 色综合色综合久久综合频道88| 欧美激情综合色综合啪啪五月| 在线视频欧美性高潮| 欧美成人精品一区二区| 国产欧美精品一区二区| 亚洲国产成人在线播放| 欧美性高潮在线| 在线观看国产精品日韩av| 成人自拍性视频| 色噜噜狠狠色综合网图区| 欧美福利在线观看| 国产精品美女主播在线观看纯欲| 国模视频一区二区三区| 亚洲国产91精品在线观看| 国产精品免费看久久久香蕉| 91干在线观看| 日韩va亚洲va欧洲va国产| 国产精品7m视频| 日韩在线观看电影| 欧美精品一二区| 97在线视频一区| 国产精品网红福利| 亚洲欧洲国产精品| 岛国av一区二区在线在线观看| 97香蕉超级碰碰久久免费的优势| 欧美日韩成人在线观看| 国产精品一区电影| 久久九九热免费视频| 亚洲精品mp4| 国产不卡av在线免费观看| 亚洲美女av网站| 日韩在线视频免费观看| 久久91精品国产91久久久| 国产精品中文在线| 久久人人爽人人爽爽久久| 97国产成人精品视频| 国产精品一区二区久久久久| 国产精品黄页免费高清在线观看| 精品久久久一区二区| 国产精品人成电影在线观看| 久久人人爽人人爽人人片亚洲| 日韩欧美中文字幕在线播放| 成人性生交xxxxx网站| 欧美一乱一性一交一视频| 中文字幕精品在线视频| 91牛牛免费视频| 亚洲最大的av网站| 亚洲福利小视频| 亚洲第一福利视频| 久久久精品久久久久| 欧美国产日韩一区| 韩国美女主播一区| 欧美在线视频a| 国产精品日韩电影| 97激碰免费视频| 国产精品久久久久久久午夜| 欧美日韩国产成人在线| 久久成人国产精品| 国产精品观看在线亚洲人成网| 亚洲欧美制服第一页| 尤物精品国产第一福利三区| 久久精品国产清自在天天线| 国产亚洲精品日韩| 日韩av在线一区二区| 欧美成人精品一区| 国产91色在线免费| 欧美精品手机在线| 97成人精品视频在线观看| 精品国产自在精品国产浪潮| 成人中文字幕+乱码+中文字幕| 在线观看亚洲视频| 亚洲视频axxx| 亚洲精品aⅴ中文字幕乱码| 91成人国产在线观看| 在线播放国产一区中文字幕剧情欧美| 日韩黄在线观看| 一区二区三区国产在线观看| 7777kkkk成人观看| 亚洲91精品在线观看| 欧美色道久久88综合亚洲精品| 久久99青青精品免费观看| 国产精品久久久久91| 亚洲天堂av网| 国产精品96久久久久久| 成人免费自拍视频| 欧美精品九九久久| 欧美大片网站在线观看| 日本成人在线视频网址| 日韩免费在线电影| 久久好看免费视频| 日韩成人xxxx|