JSON.stringify通过replacer过滤内容、space控制格式、toJSON自定义序列化,实现灵活的对象转字符串。

JSON.stringify 是 JavaScript 中将对象或值转换为 JSON 字符串的方法,它支持三个参数来定制序列化行为。
第二个参数 replacer 可以是一个函数或数组,用于过滤或修改序列化的结果。
• 如果是函数,它会在序列化过程中被调用,接收两个参数:键(key)和值(value),根据返回值决定如何处理该属性。返回 undefined 表示忽略该属性。 • 如果是数组,则只包含数组中列出的属性名,其他属性会被排除。示例:
const user = { name: "Alice", age: 25, secret: "123" };
立即学习“Java免费学习笔记(深入)”;
// 使用函数过滤
JSON.stringify(user, (key, value) => key === "secret" ? undefined : value); // {"name":"Alice","age":25}
// 使用数组指定保留字段
JSON.stringify(user, ["name"]); // {"name":"Alice"}
第三个参数 space 用于控制格式化输出的缩进,提升可读性。
本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,
0
示例:
JSON.stringify({a:1}, null, 2);
// 格式化输出:
{ "a": 1 }
虽然第一个参数是待序列化的值,但它的类型会影响结果:
• 如果对象有 toJSON 方法,JSON.stringify 会使用该方法的返回值而不是原对象。 • 这提供了一种自定义序列化逻辑的方式。示例:
const data = { now: new Date(), toJSON() { return { time: this.now.toISOString() }; } };
JSON.stringify(data); // {"time":"2024-01-01T00:00:00.000Z"}
基本上就这些。replacer 控制内容,space 控制格式,toJSON 提供对象级别的自定义。合理使用能让序列化更灵活。
以上就是JavaScript中的JSON.stringify有哪些参数可以定制?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号