JSON.stringify()认识

深浅拷贝:JSON.parse(JSON.stringify(obj))

序列化:将对象转换为JSON字符串

javascript 复制代码
let obj = {
    name: 'String'
}
console.log(JSON.stringify(obj));   // {"name":"String"}

序列化弊端:

对象属性值为``函数序列化后属性丢失。
javascript 复制代码
let obj = {
    name: 'String',
    foo: function () {
        console.log(`${ this.name }是一个小菜鸟!`)
    }
}
console.log(JSON.stringify(obj));   // {"name":"String"}
对象属性值为undefined序列化后该属性会丢失。
javascript 复制代码
let obj = {
    name: undefined
}
console.log(JSON.stringify(obj));   // {}
对象属性值正则表达式序列化后该属性为{}
javascript 复制代码
let obj = {
    name: 'String',
    zoo: /^i/ig,
    foo: function () {
        console.log(`${ this.name }是一个小菜鸟!`)
    }
}
console.log(JSON.stringify(obj));   // {"name":"String","zoo":{}}
数组含对象,对象属性值为undefined序列化后该属性也会丢失。
javascript 复制代码
let arr = [
    {
        name: undefined
    }
]
console.log(JSON.stringify(arr));   // [{}]

序列化扩展:

JSON.stringify()``第二参数传入一个数组,值为对象key,可获取该项。
javascript 复制代码
let obj = {
    name: 'String',
    age: 25,
    hobby: ['JavaScript', 'Vue']
}
let res = JSON.stringify(obj, ['name']);

console.log(res);    // {"name":"String"}
JSON.stringify()``第二参数传入一个函数,可遍历修改每一项。
javascript 复制代码
let obj = {
    name: 'String',
    age: 25,
    hobby: ['JavaScript', 'Vue']
}
let res = JSON.stringify(obj, (key, value) => {
    if (key === 'age') return undefined;
    return value;
});

console.log(res);   // {"name":"String","hobby":["JavaScript","Vue"]}
JSON.stringify()第三参数可传入数字,表示缩进多少字符
javascript 复制代码
let obj = {
    name: 'String',
    age: 25,
    hobby: ['JavaScript', 'Vue']
}
let res = JSON.stringify(obj, null, 2);

console.log(res);  // 表示缩进2行

// {
// "name": "String",
//  "age": 25,
//  "hobby": [
//    "JavaScript",
//    "Vue"
//  ]
// }
Object自身含有toJSON属性,只有被 JSON.stringify() 调用时,toJSON 方法才会自动执行,用于自定义数据样式。
javascript 复制代码
let obj = {
    name: '小明',
    age: 25,
    toJSON: function () {
        return {
            message: `${ this.name }的年龄为${ this.age }`
        }
    }
}
let res = JSON.stringify(obj);

console.log(res);   // {"message":"小明的年龄为25"}

注:toJSON 方法只在 JSON.stringify() 被调用时起作用。如果你直接访问对象的 toJSON 属性,你会得到函数本身,而不是它的执行结果。

相关推荐
来自星星的坤2 小时前
【Vue 3 + Vue Router 4】如何正确重置路由实例(resetRouter)——避免“VueRouter is not defined”错误
前端·javascript·vue.js
香蕉可乐荷包蛋6 小时前
浅入ES5、ES6(ES2015)、ES2023(ES14)版本对比,及使用建议---ES6就够用(个人觉得)
前端·javascript·es6
未来之窗软件服务7 小时前
资源管理器必要性———仙盟创梦IDE
前端·javascript·ide·仙盟创梦ide
liuyang___8 小时前
第一次经历项目上线
前端·typescript
西哥写代码8 小时前
基于cornerstone3D的dicom影像浏览器 第十八章 自定义序列自动播放条
前端·javascript·vue
清风细雨_林木木8 小时前
Vue 中生成源码映射文件,配置 map
前端·javascript·vue.js
FungLeo8 小时前
node 后端和浏览器前端,有关 RSA 非对称加密的完整实践, 前后端匹配的代码演示
前端·非对称加密·rsa 加密·node 后端
雪芽蓝域zzs9 小时前
JavaScript splice() 方法
开发语言·javascript·ecmascript
不灭锦鲤9 小时前
xss-labs靶场第11-14关基础详解
前端·xss
不是吧这都有重名9 小时前
利用systemd启动部署在服务器上的web应用
运维·服务器·前端