JSON

JSON: 用于數(shù)據(jù)交換的文本格式
優(yōu)點:書寫簡單擎宝;符合JS原生語法


復(fù)合類型的值只能是數(shù)組或?qū)ο螅荒苁呛瘮?shù)涡上、正則表達(dá)式對象趾断、日期對象。

簡單類型的值只有四種:字符串吩愧、數(shù)值(必須以十進(jìn)制表示)芋酌、布爾值和null(不能使用NaN, Infinity, -Infinity和undefined)。

字符串必須使用雙引號表示雁佳,不能使用單引號脐帝。

對象的鍵名必須放在雙引號里面。

數(shù)組或?qū)ο笞詈笠粋€成員的后面糖权,不能加逗號堵腹。


空數(shù)組和空對象都是合格的 JSON 值,null本身也是一個合格的 JSON 值星澳。

JSON.stringify方法用于將一個值轉(zhuǎn)為字符串疚顷。該字符串符合 JSON 格式,并且可以被JSON.parse方法還原。


JSON.stringify([1, "false", false])
// '[1,"false",false]'

JSON.stringify({ name: "張三" })
// '{"name":"張三"}'

JSON.stringify('foo') === "\"foo\"" // true

字符串foo腿堤,被轉(zhuǎn)成了""foo""

如果原始對象中阀坏,有一個成員的值是undefined、函數(shù)或 XML 對象释液,這個成員會被過濾全释。
如果數(shù)組的成員是undefined、函數(shù)或 XML 對象误债,則這些值被轉(zhuǎn)成null浸船。
正則對象會被轉(zhuǎn)成空對象。
JSON.stringify方法會忽略對象的不可遍歷屬性寝蹈。

JSON.stringify方法還可以接受一個數(shù)組李命,作為第二個參數(shù),指定需要轉(zhuǎn)成字符串的屬性箫老。只對對象的屬性有效封字,對數(shù)組無效

var obj = {
  'prop1': 'value1',
  'prop2': 'value2',
  'prop3': 'value3'
};

var selectedProperties = ['prop1', 'prop2'];

JSON.stringify(obj, selectedProperties)
// "{"prop1":"value1","prop2":"value2"}"

第二個參數(shù)還可以是一個函數(shù),用來更改JSON.stringify的默認(rèn)行為耍鬓。

function f(key, value) {
  if (typeof value === "number") {
    value = 2 * value;
  }
  return value;
}

JSON.stringify({ a: 1, b: 2 }, f)
// '{"a": 2,"b": 4}'

JSON.stringify還可以接受第三個參數(shù)阔籽,用于增加返回的JSON字符串的可讀性。如果是數(shù)字牲蜀,表示每個屬性前面添加的空格(最多不超過10個)笆制;如果是字符串(不超過10個字符),則該字符串會添加在每行前面涣达。

JSON.stringify({ p1:1, p2:2 }, null, '|-');
/*
"{
|-"p1": 1,
|-"p2": 2
}"
*/

如果對象有自定義的toJSON方法在辆,那么JSON.stringify會使用這個方法的返回值作為參數(shù),而忽略原對象的其他屬性度苔。

var user = {
  firstName: '三',
  lastName: '張',

  get fullName(){
    return this.lastName + this.firstName;
  },

  toJSON: function () {
    var data = {
      firstName: this.firstName,
      lastName: this.lastName
    };
    return data;
  }
};

JSON.stringify(user)
// "{"firstName":"三","lastName":"張"}"

toJSON方法的一個應(yīng)用是匆篓,將正則對象自動轉(zhuǎn)為字符串。

RegExp.prototype.toJSON = RegExp.prototype.toString;
JSON.stringify(/foo/) // ""/foo/""

JSON.parse方法用于將JSON字符串轉(zhuǎn)化成對象寇窑。

var o = JSON.parse('{"name": "張三"}');
o.name // 張三
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸦概,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子甩骏,更是在濱河造成了極大的恐慌窗市,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件横漏,死亡現(xiàn)場離奇詭異谨设,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)缎浇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進(jìn)店門扎拣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事二蓝∮” “怎么了?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵刊愚,是天一觀的道長踊跟。 經(jīng)常有香客問我,道長鸥诽,這世上最難降的妖魔是什么商玫? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮牡借,結(jié)果婚禮上拳昌,老公的妹妹穿的比我還像新娘。我一直安慰自己钠龙,他們只是感情好炬藤,可當(dāng)我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著碴里,像睡著了一般沈矿。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上咬腋,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天羹膳,我揣著相機(jī)與錄音,去河邊找鬼帝火。 笑死溜徙,一個胖子當(dāng)著我的面吹牛湃缎,可吹牛的內(nèi)容都是我干的犀填。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嗓违,長吁一口氣:“原來是場噩夢啊……” “哼九巡!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蹂季,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤冕广,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后偿洁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體撒汉,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年涕滋,在試婚紗的時候發(fā)現(xiàn)自己被綠了睬辐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖溯饵,靈堂內(nèi)的尸體忽然破棺而出侵俗,到底是詐尸還是另有隱情,我是刑警寧澤丰刊,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布隘谣,位于F島的核電站,受9級特大地震影響啄巧,放射性物質(zhì)發(fā)生泄漏寻歧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一秩仆、第九天 我趴在偏房一處隱蔽的房頂上張望熄求。 院中可真熱鬧,春花似錦逗概、人聲如沸弟晚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽卿城。三九已至,卻和暖如春铅搓,著一層夾襖步出監(jiān)牢的瞬間瑟押,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工星掰, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留橘蜜,地道東北人孩擂。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親抄瓦。 傳聞我的和親對象是個殘疾皇子彼妻,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,864評論 2 354

推薦閱讀更多精彩內(nèi)容