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 属性,你会得到函数本身,而不是它的执行结果。

相关推荐
网络研究院17 小时前
苹果 Safari 地址栏可能被超大光标视觉欺骗
前端·safari·苹果
阿华的代码王国18 小时前
【Android】JSONObject和Gson的使用
android·java·json·gson·jsonobject
slongzhang_18 小时前
html添加水印
前端·html
Small black human18 小时前
前端-什么是Vue
前端·javascript·vue.js
IT 前端 张19 小时前
Axios与Ajax:现代Web请求大比拼
前端·javascript·ajax
ikun778g20 小时前
uniapp使用uview UI,自定义级联选择组件
前端·前端框架·uni-app
java水泥工20 小时前
基于Echarts+HTML5可视化数据大屏展示-惠民服务平台
前端·echarts·html5
万少21 小时前
可可图片编辑 HarmonyOS(3)应用间分享图片
前端·harmonyos·客户端
Hy行者勇哥21 小时前
现代软件系统架构:前端、后端、数据库、部署、算法与AI学习的结构与交互分析
前端·数据库·学习
前端开发爱好者1 天前
90% 前端都不知道的 20 个「零依赖」浏览器原生能力!
前端·javascript·vue.js