前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript 学习-6.对象(object)的序列化和反序列化

JavaScript 学习-6.对象(object)的序列化和反序列化

作者头像
上海-悠悠
发布2022-05-17 19:09:14
1.9K0
发布2022-05-17 19:09:14
举报

前言

在JavaScript中的序列化和反序列化。

对象的序列化

当我们需要向后端传json字符串的时候,需将JavaScript的对象转成json格式,这个过程就是序列化。

代码语言:javascript
复制
var person = {
    name: "yoyo",
    age: 22,
    address: "上海市"
};
console.log(person);  // {name: 'yoyo', age: 22, address: '上海市'}
alert(person);  // [object Object]

如果我们需要把数据传到后端,是需要转成标准的json格式,后端才能正常的识别到。于是需把JavaScript的object对象转成json。

最常用的是内置方法JSON.stringify(obj)

代码语言:javascript
复制
var person = {
    name: "yoyo",
    age: 22,
    address: "上海市"
};

console.log(JSON.stringify(person));  // {"name":"yoyo","age":22,"address":"上海市"}
alert(JSON.stringify(person));  // {"name":"yoyo","age":22,"address":"上海市"}

反序列化

后端通过接口给前端提供json数据,JavaScript接收json数据后续解析成object对象才好取值,这个过程叫反序列化。 最常用的是内置方法JSON.parse(text)

代码语言:javascript
复制
// text 是一个 json 字符串
text = '{"name":"yoyo","age":22,"address":"上海市"}'
console.log(JSON.parse(text))
alert(JSON.parse(text))

兼容性

对象的序列化和反序列化使用 JavaScript 提供的内置方法JSON.stringify(obj)JSON.parse(text)基本就可以了。 (但是对于IE8以下的低版本兼容会有一些问题, 不过最近IE浏览器都宣布退出了,再也不用担心这个问题了)

json.js 是 JSON官方(http://www.json.org/)提供的在JavaScript中解析JSON的js包,主要为了解决不同浏览器的兼容性。 网上会看到json.js、json2.js、json3.js是从旧到新的三个版本,现在一般使用json3.js。

JSON官方(http://www.json.org/)提供了一个json3.js,提供了JSON的序列化和反序列化方法,可以将一个JSON对象转换成JSON字符串,也可以将一个JSON字符串转换成一个JSON对象。 这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;

json3.js是与各种JavaScript平台兼容的现代JSON实现,包括Internet Explorer 6,Opera 7,Safari 2和Netscape 6.当前版本是3.3.2。

可以在 https://bestiejs.github.io/json3/ 获取到这个最新的json3.js

这里提供一个json2.js github 下载地址https://github.com/douglascrockford/JSON-js

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-05-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 从零开始学自动化测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 对象的序列化
  • 反序列化
  • 兼容性
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档