在开发工作中,我们可能会碰到这样的需求:需要将某个对象内容弹窗显示或者保存在文件中,这时候如果你直接弹窗的话,很可能就是下面这样的:
因为很多接口它对参数有要求,比如只能是字符串之类高中数学解题技巧的。
这时候,六年级上册语文第三单元试卷就需要我们将对象转换为字符串进行输出,json.stringify() 方法就可以帮我们实现将对象转为字符串的过程。
json.stringify() 方法将一个 javascript 对象或值转换为 json 字符串,如果指定了一个 replacer 函数,则可以选择性地替换值,或者指定的 replacer 是数组,则可选择性地仅包含数组指定的属性。
json.stringify(value[, replacer [, space]])
一个表示给定值的json字符串。
console.log(json.stringify({name: "obj"}))// '{"name": "obj"}'
replacer 参数可以是一个函数或者一个数组。作为函数,它有两个参数,键(key)和值(value),它们都会全城热恋影评被序列化。
在开始时, replacer 函数会被传入一个空字符串作为 key 值,代表着要被 stringify 的这个对象。随后每个对象或数组上的属性会被依次传入。
函数应当返回json字符串中的value, 如下所示:
如果返回一个 number,转换成相应的字符串作为属性值被添加入 json 字符串。如果返回一个 string,该字符串作为属性值被添加入 json 字符串。如果返回一个 boolean, “true” 或者 “fal” 作为属性值被添加入 json 字符串。如果返回任何其他对象,该对象递归地序列化成 json 字符串,对每个属性调用 replacer 方法。除非该对象是一个函数,这种情况将不会被序列化成 json 字符串。如果返回 undefined,该属性值不会在 json 字符串中输出。有以下对象:
const data = [ { name: "person1", x: 0, age: 18, isstudent: true }, { name: "person2", x: 1, age: 25, isstudent: fal }, { name: "person3", x: 0, age: 15, isstudent: true }]
接下来我们针对这个对象做各种需求实现。
const res = json.stringify(data, ["name", "x"])console.log(res);// `[{"name":"person1","x":0},{"name":"person2","x":1},{"name":"person3","x":0}]`
json.stringify() 提供了分离出自己需要的那部分数据。
const res = json.stringify(data, (key, value) => { if (key == 'x') { return ["女", '男'][value]; } return value;})console.log(res);// `[{"name":"person1","x":"女","age":18,"isstudent":true},{"name":"person2","x":"男","age":25,"isstudent":fal},{"name":"person3","x":"女","age":15,"isstudent":true}]`
json.stringify() 提供了回调函数做一个映射关系。
const res = json.stringify(data, ["name", "x"],4)console.log(res);
输出如下:
这里使用了 4 个空格作为层级缩进。
注意:使用 “t” 得到的结果和使用 4 个空格得到的结果看起来很像,但实际不是一回事。
json.stringify() 方法可以通过参数控制输出意料之外情理之中的数据和格式,灵活应用它会大大提高我们的工作效率。
本文发布于:2023-04-05 11:49:18,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/dcd5a6d7d367b141561daad276dc95ba.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:js处理json数据(js判断数据类型讲解).doc
本文 PDF 下载地址:js处理json数据(js判断数据类型讲解).pdf
留言与评论(共有 0 条评论) |