首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >选择篇(003)-下面代码的输出是什么

选择篇(003)-下面代码的输出是什么

作者头像
齐丶先丶森
发布2022-05-12 21:23:59
发布2022-05-12 21:23:59
2620
举报
文章被收录于专栏:前端面试秘籍前端面试秘籍
代码语言:javascript
复制
const settings = {
    username: 'lydiahallie',
    level: 19,
    health: 90
};
const data = JSON.stringify(settings, ['level', 'health']);
console.log(data);
代码语言:javascript
复制
A: "{"level":19, "health":90}"
B: "{"username": "lydiahallie"}"
C: "{"level", "health"]"
D: "{"username": "lydiahallie", "level":19, "health":90}"

参考答案: A 解析: JSON.stringify 的第二个参数是替代者(replacer). 替代者(replacer)可以是个函数或数组,用以控制哪些值如何被转换为字符串。 如果替代者(replacer)是个数组,那么就只有包含在数组中的属性将会被转化为字符串。在本例中,只有名为'level'和'health'的属性被包括进来,'username'则被排除在外。data就等于 "{"level":19, "health":90}" 而如果替代者(replacer)是个函数,这个函数将被对象的每个属性都调用一遍。函数返回的值会成为这个属性的值,最终体现在转化后的 JSON 字符串中(译者注: Chrome 下,经过实验,如果所有属性均返回同一个值的时候有异常,会直接将返回值作为结果输出而不会输出 JSON 字符串),而如果返回值为 undefined , 则该属性会被排除在外。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端面试秘籍 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档