深入探究JSON.stringify()方法:定制化输出JSON数据

JSON.stringify() 是 JavaScript 中的一个函数,用于将 JavaScript 对象或值转换为 JSON 格式的字符串。

在使用 JSON.stringify() 方法时,我们需要传入一个 JavaScript 对象或值作为参数,然后该方法会将其转换为 JSON 格式的字符串。如果对象中包含了函数、未定义的值、循环引用等特殊类型的数据,那么在转换时会忽略这些数据。

基本用法

下面是一个使用 JSON.stringify() 方法的示例:

javascript 复制代码
const obj = {
    name:'张三',
    age: 20,
    gender:'男',
    hobbies:['游泳','篮球','阅读'],
    address: {
        city:'北京',
        district:'海淀区',
        street:'中关村'
    }
};
const jsonString = JSON.stringify(obj);
console.log(jsonString);

上面的示例中,我们定义了一个包含了字符串、数字、数组、对象等多种类型数据的 JavaScript 对象,并将其作为参数传入 JSON.stringify() 方法中。最后,该方法将该对象转换为 JSON 格式的字符串,并将其打印输出到控制台。

转换后的 JSON 格式的字符串如下所示:

json 复制代码
{
    "name":"张三",
    "age": 20,
    "gender":"男",
    "hobbies": [
        "游泳",
        "篮球",
        "阅读"
    ],
    "address": {
        "city":"北京",
        "district":"海淀区",
        "street":"中关村"
    }
}

高级用法

replacer 参数

replacer 是一个函数或数组,用于控制序列化过程中哪些属性应该被序列化。

  • 如果是一个函数, 则它会在序列化过程中每一个属性都被遍历到时被调用,接受两个参数:属性名和属性值。在函数中,你可以返回一个新的值,以控制序列化的结果,或者返回 undefined,以排除当前属性。
  • 如果是一个数组, 则仅序列化数组中包含的属性。
vbnet 复制代码
const person = {
    name: "Alice",
    age: 25,
    job: "Software Engineer",
    salary: 100000,
    company: "ABC Inc."
};
//使用函数控制序列化结果
const replacerFunc = (key, value) => {
    if(key === "salary" || key === "company") {
    return undefined;//排除 salary 和 company属性
    } else {
    return value;
    }
};
const jsonString1 = JSON.stringify(person, replaceerFunc)
console.log(jsonString1);
//输出:{"name":"Alice","age":25,"job": "Software Engineer"}

//使用数组控制序列化结果
const replacerArray=["name", "age", "job"];//仅包含name、age和job
const jsonString2 = JSON.stringify(person, replaceerArray)
console.log(jsonString2);
//输出:{"name":"Alice","age":25,"job": "Software Engineer"}

space 参数

参数 space 是用于控制生成 JSON 字符串的缩进和格式化的。它可以传入一个数字,表示每个缩进级别的空格数,或者传入一个字符串,用作缩进符号。

如果你不需要缩进,可以将它设为 0 或空字符串。

arduino 复制代码
const person = {
    name: "Alice",
    age:25,
    job: "Software Engineer",
    salary: 100000,
    company: "ABC Inc."
};
  • 使用数字控制缩进格式
vbscript 复制代码
const jsonStringi = JSON.stringify(person, null,2);//用2个空格缩进
console.log(jsonString1);
输出:
/*
{
  "name": "Alice",
  "age":25,
  "job": "Software Engineer",
  "salary": 100000,
  "company": "ABC Inc."
}
*/
  • 使用字符串控制缩进格式
vbscript 复制代码
const jsonString2 = JSON.stringify(person, null,,"--");//用--缩进
console.log(jsonString2);
/*
输出:
{
--"name": "Alice",
--"age": 25,
--"job": "Software Engineer",
--"salary": 10000,
--"company": "ABC Inc."
}
*/
  • 不使用缩进
vbscript 复制代码
const jsonString3 = JSON.stringify(person, null, O);//不使用缩进
console.log(jsonString3);//输出:{"name":"Alice","age":25,"job": "Software Engineer","salary": 10000,"company": "ABC Inc."

"罗马"非一日建成,"罗码"也非一帆风顺,虽然条条大路通罗马,但"罗码之路"还有待验证

相关推荐
娃哈哈哈哈呀20 分钟前
formData 传参 如何传数组
前端·javascript·vue.js
tsumikistep1 小时前
【前后端】接口文档与导入
前端·后端·python·硬件架构
行走的陀螺仪2 小时前
.vscode 文件夹配置详解
前端·ide·vscode·编辑器·开发实践
2503_928411562 小时前
11.24 Vue-组件2
前端·javascript·vue.js
Bigger3 小时前
🎨 用一次就爱上的图标定制体验:CustomIcons 实战
前端·react.js·icon
谢尔登3 小时前
原来Webpack在大厂中这样进行性能优化!
前端·webpack·性能优化
g***B7383 小时前
JavaScript在Node.js中的模块系统
开发语言·javascript·node.js
Z***25804 小时前
JavaScript在Node.js中的Deno
开发语言·javascript·node.js
cypking4 小时前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端·javascript·vue.js
San30.4 小时前
ES6+ 新特性解析:让 JavaScript 开发更优雅高效
开发语言·javascript·es6