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

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

相关推荐
masa01019 分钟前
JavaScript--JavaScript基础
开发语言·javascript
让开,我要吃人了2 小时前
HarmonyOS开发实战(5.0)实现二楼上划进入首页效果详解
前端·华为·程序员·移动开发·harmonyos·鸿蒙·鸿蒙系统
everyStudy3 小时前
前端五种排序
前端·算法·排序算法
甜兒.4 小时前
鸿蒙小技巧
前端·华为·typescript·harmonyos
她似晚风般温柔7897 小时前
Uniapp + Vue3 + Vite +Uview + Pinia 分商家实现购物车功能(最新附源码保姆级)
开发语言·javascript·uni-app
Jiaberrr8 小时前
前端实战:使用JS和Canvas实现运算图形验证码(uniapp、微信小程序同样可用)
前端·javascript·vue.js·微信小程序·uni-app
everyStudy8 小时前
JS中判断字符串中是否包含指定字符
开发语言·前端·javascript
城南云小白8 小时前
web基础+http协议+httpd详细配置
前端·网络协议·http
前端小趴菜、8 小时前
Web Worker 简单使用
前端
web_learning_3218 小时前
信息收集常用指令
前端·搜索引擎