JavaScript中的對象序列化介紹
與Java語言一樣,JavaScript中可以對對象進行序列化和反序列化,藉此對對象進行保存。ECMAScript 5標準中,JavaScript中的對象序列化是通過JSON.stringify()來實現(xiàn)的,而反序列化則通過JSON.parse()來實現(xiàn):
var o = {x:1, y:29, z:42};
var s = JSON.stringify(o);
console.log(s);//{"x":1,"y":29,"z":42}
var c = JSON.parse(s);
console.log(c);//Object {x=1, y=29, z=42}
對于僅支持ECMAScript 3標準的瀏覽器,可以使用Douglas Crockford寫的json2.js (https://github.com/douglascrockford/JSON-js)。
在對對象進行序列化過程中,NaN、Infinity和-Infinity將被序列化成”null”;Date對象將被序列化成表示相應時間的字符串(但當使用JSON.parse()反序列化時,該時間字符串將作為普通字符串存在,不會被重新構建為Date對象)。
使用JSON.stringify()序列化對象時,所序列化的property僅限于對象自身(Own)的enumerable的property。而在JSON.stringify()運行時,JavaScript會先查找需要序列化的對象中是否有toJSON()方法,如果toJSON()方法存在,則調用該方法并將其返回的結果作為序列化的目標。如果toJSON()方法不存在,則使用默認的序列化方法。
- GSON實現(xiàn)Java對象的JSON序列化與反序列化的實例教程
- jQuery實現(xiàn)form表單元素序列化為json對象的方法
- java對象序列化與反序列化的默認格式和json格式使用示例
- 基于jQuery的一個擴展form序列化到json對象
- 詳解JavaScript對象序列化
- JavaScript 序列化對象實現(xiàn)代碼
- js解析與序列化json數(shù)據(jù)(一)json.stringify()的基本用法
- jquery序列化form表單使用ajax提交后處理返回的json數(shù)據(jù)
- js解析與序列化json數(shù)據(jù)(二)序列化探討
- Json序列化和反序列化方法解析
- 淺析JSON序列化與反序列化
- js解析與序列化json數(shù)據(jù)(三)json的解析探討
- JSON與js對象序列化實例詳解
相關文章
使用Javascript開發(fā)sliding-nav帶滑動條效果的導航插件
這篇文章主要介紹了使用Javascript開發(fā)sliding-nav帶滑動條效果的導航插件,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03JavaScript函數(shù)及其prototype詳解
這篇文章主要介紹了JavaScript函數(shù)及其prototype詳解的相關資料,需要的朋友可以參考下2023-03-03微信小程序實現(xiàn)打開并下載服務器上面的pdf文件到手機
這篇文章主要介紹了微信小程序實現(xiàn)打開并下載服務器上面的pdf文件到手機,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09