JSON.stringify(value, replacer, space)
JSON.stringify(obj)是常用的将js对象转换为json字符串的方法,但很少有人知道,该方法其实还有另外2个参数。
1、方法
方法定义:JSON.stringify(value, replacer, space)
参数说明:value:js对象
replacer:替换对象,可以是一个方法、对象或数组,将value按照替换规则展示。
space:填充参数,可以是数字或字符串,将value按照参数进行格式化展示。
方法说明:将value对象转换为指定格式的json文本。
2、参数value
如果不转换对象注解输出对象的效果:[object,object]
使用JSON.stringify(value)的效果
js:
$(function(){ $("#strTest").text(JSON.stringify("字符串测试")); var testObj = { name:"张三", age:28, gender:"男" }; $("#objTest").text(JSON.stringify(testObj)); var testArr = [{ name:"张三", age:20, gender:"男" }, { name:"李思", age:28, gender:"女" }] $("#arrTest").text(JSON.stringify(testArr)); })
页面效果:
3、参数replacer
参数为function(key,value),会根据函数返回值替换value中的值。
例如替换上面对象的gender为英文大写。
var testObj = { name:"张三", age:28, gender:"man" }; $("#objTest").text(JSON.stringify(testObj,testReplacer)); var testArr = [{ name:"张三", age:20, gender:"gril" }, { name:"李思", age:28, gender:"gril" }] $("#arrTest").text(JSON.stringify(testArr,testReplacer)); function testReplacer(key,value){//key为对象属性名,value为对象属性值,会遍历testObj或testArr来执行该函数 if(key=="gender"){ value = value.toUpperCase(); } return value; }
参数为object对象,并不会影响原对象。
参数为数组时,会遍历数组的值,以数组的值作为value的属性。如果value原本包含该属性,那么显示该属性,如果不包含则不显示。例如:
var name = ["name","gril","gender"]; var testObj = { name:"张三", age:28, gender:"man" }; $("#objTest").text(JSON.stringify(testObj,name)); var testArr = [{ name:"张三", age:20, gender:"gril" }, { name:"李思", age:28, gender:"gril" }] $("#arrTest").text(JSON.stringify(testArr,name));
上面的name数组包含3个值,而testObj对象值包含其中的name属性和gender属性,并不存在gril属性,所以,只会显示name和gender属性。效果如下
如果将参数改为一个对象数组,那么因为对象不是一个属性,key值为“”,所以会显示一个空对象:{}。
4、参数space
如果space参数为数字n时,value对象将被格式化,并且属性会缩进n个字符。n>10时,只会缩进10个空格,n<10时,缩进n个空格,n<=0时不进行格式化。例如:
$("#objTest").text(JSON.stringify(testObj,null,8)); $("#arrTest").text(JSON.stringify(testArr,name,8));
缩进8个空格展示。
如果space为特殊字符时,按照特殊字符格式化。
例如:"\n":每行换行。"aa":每行头部添加aa字母。
$("#objTest").text(JSON.stringify(testObj,null,"\n")); $("#arrTest").text(JSON.stringify(testArr,name,"aa"));
效果如下:
本文来自博客园,作者:喆星高照,转载请注明原文链接:https://www.cnblogs.com/houxianzhou/p/15392077.html
分类:
javascript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?