深入探究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."

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

相关推荐
长空任鸟飞_阿康11 分钟前
AI 多模态全栈应用项目描述
前端·vue.js·人工智能·node.js·语音识别
Mintopia13 分钟前
🌐 实时协同 AIGC:多人在线 Web 创作的技术架构设计
前端·人工智能·trae
Mintopia16 分钟前
🔥 “Solo Coding”的近期热度解析(截至 2025 年末)
前端·人工智能·trae
顾安r34 分钟前
11.14 脚本网页 迷宫逃离
服务器·javascript·游戏·flask·html
顾安r1 小时前
11.14 脚本网页游戏 猜黑红
前端·javascript·游戏·flask·html
码码哈哈0.01 小时前
Vue 3 + Vite 集成 Spring Boot 完整部署指南 - 前后端一体化打包方案
前端·vue.js·spring boot
@菜菜_达2 小时前
interact.js 前端拖拽插件
开发语言·前端·javascript
Baklib梅梅2 小时前
故事叙述的力量:用Baklib创作让内容更具温度与共鸣
前端·ruby on rails·前端框架·ruby
一个假的前端男2 小时前
uniapp 3端轮播
前端·javascript·uni-app
Fantasydg3 小时前
Request Response对象
前端