前端技术之:JSON.stringfy详细说明
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了前端技术之:JSON.stringfy详细说明,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1758字,纯文字阅读大概需要3分钟。
内容图文
JSON.stringify() 语法
JSON.stringify(value[, replacer[, space]])
value 被序列化为字符串的对象
replacer 根据类型不同,其行为也不一样。如果是一个函数类型,则相当于是一个filter,可以对序列化的键值对进行加工处理;如果是一个数组,则只有符合数组中名称的key才会被输出
space 如果为0或不填,则不进行格式化处理;如果为大于0的数值,则表示每级缩进空格数;如果是一个字符串,则表示每级缩进时替代空格进行填充的字符串内容。
通过以下的data作为示例:
let data = {
name: ‘wang‘,
age: 28,
address: null,
favorites: undefined,
company: {
name: ‘world village‘,
address: ‘Beijing city‘
}
}
不加任何参数,直接输出:
console.log(JSON.stringify(data))
结果为:
{"name":"wang","age":28,"address":null,"company":{"name":"world village","address":"Beijing city"}}
第二个参数为数组:
console.log(JSON.stringify(data, [‘name‘, ‘age‘]))
结果为:
{"name":"wang","age":28}
第二个参数是一个函数:
console.log(
JSON.stringify(data, (k, v) => {
if (‘age‘ == k) {
return undefined
}
return v
})
)
结果为:
{"name":"wang","address":null,"company":{"name":"world village","address":"Beijing city"}}
如果第三个参数为0或者null:
console.log(JSON.stringify(data, null, 0))
则结果为:
{"name":"wang","age":28,"address":null,"company":{"name":"world village","address":"Beijing city"}}
如果第三个参数为大于0的数值:
console.log(JSON.stringify(data, null, 2))
则结果为:
{
"name": "wang",
"age": 28,
"address": null,
"company": {
"name": "world village",
"address": "Beijing city"
}
}
如果第三个参数为字符串:
console.log(JSON.stringify(data, null, ‘**‘))
则结果为:
{
**"name": "wang",
**"age": 28,
**"address": null,
**"company": {
****"name": "world village",
****"address": "Beijing city"
**}
}
如果过滤值为null或者undefined的键值对?
let data = {
name: ‘wang‘,
age: 28,
address: null,
favorites: undefined,
men: true,
women: false,
company: {
name: ‘world village‘,
address: ‘Beijing city‘
}
}
console.log(
JSON.stringify(data, (k, v) => {
if (null != v && undefined != v) return v
})
)
原文:https://www.cnblogs.com/popgis/p/11756624.html
内容总结
以上是互联网集市为您收集整理的前端技术之:JSON.stringfy详细说明全部内容,希望文章能够帮你解决前端技术之:JSON.stringfy详细说明所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。