woniu50673488 2021-03-12 10:44 采纳率: 100%
浏览 81
已采纳

ES6 MDN的例子, 参数结构看不明白


var elements = [
  'Hydrogen',
  'Helium',
  'Lithium',
  'Beryllium'
];

// 在这个例子中,因为我们只需要 `length` 属性,所以可以使用参数解构
// 需要注意的是字符串 `"length"` 是我们想要获得的属性的名称,而 `lengthFooBArX` 则只是个变量名,
// 可以替换成任意合法的变量名


elements.map(({ "length": lengthFooBArX }) => lengthFooBArX); // [8, 6, 7, 9]

 

请哪位大哥解释一下最后面一句,小弟看不明白。

  • 写回答

1条回答 默认 最新

  • 幻灰龙 2021-03-12 13:53
    关注

    一开始是这样的:

    elements.map((element) => element.length );

    当然也可以这样:

    elements.map((element) => {
      return element.length;
    });

    然后可以这样:

    elements.map((element) => {
      const {length} = element
      return length;
    });

    当然这等价于

    elements.map((element) => {
      const {length: lengthFooBarX} = element
      return lengthFooBarX;
    });

    简写下,直接在回调函数参数那里解构,就是这样

    elements.map(({length: lengthFooBarX}) => {
      return lengthFooBarX;
    });

    再简写下:

    elements.map(({length: lengthFooBarX}) => lengthFooBarX );
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵