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

相关推荐
爱勇宝1 天前
小红花成长新版:模板来了,鼓励也更容易开始
前端·后端·程序员
竹林8181 天前
Solana前端开发:我在一个NFT铸造页面上被@solana/web3.js的Connection和Transaction签名坑了两天
前端
冬奇Lab1 天前
每日一个开源项目(第144篇):ai-website-cloner-template - 一条命令、多 Agent 并行,把任意网站逆向成 Next.js 代码
前端·人工智能·开源
玄玄子1 天前
webpack publicPath作用原理
前端·webpack·程序员
HduSy1 天前
帮 Claude Code 做了个菜单栏 Token 看板,聊聊里面的一些实现逻辑
前端
minglie1 天前
一个置换问题
javascript
用户059540174461 天前
用了6个月LangChain,才发现AI Agent的记忆存储一直有坑——写了23个Pytest用例才彻底修好
前端·css
奶油mm1 天前
我偷偷把公司的祖传 jQuery 项目改成了 Vue3,CTO 没发现,但全组都来抄我的代码了
前端
用户2136610035721 天前
Vue2非父子通信与动态组件
前端·vue.js
默_笙1 天前
🌀 别再手动写 Prompt 了!我让 AI 自己循环改到满意为止
javascript