数组映射到对象

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<!DOCTYPE html>
<head>
    <meta charset="utf-8"/>
</head>
<p>
    你有一个 user 对象数组,每个对象都有 name,surname 和 id。
     
    编写代码以该数组为基础,创建另一个具有 id 和 fullName 的对象数组,其中 fullName 由 name 和 surname 生成。
     
    例如:
     
    let john = { name: "John", surname: "Smith", id: 1 };
    let pete = { name: "Pete", surname: "Hunt", id: 2 };
    let mary = { name: "Mary", surname: "Key", id: 3 };
     
    let users = [ john, pete, mary ];
     
    let usersMapped = /* ... your code ... */
     
    /*
    usersMapped = [
      { fullName: "John Smith", id: 1 },
      { fullName: "Pete Hunt", id: 2 },
      { fullName: "Mary Key", id: 3 }
    ]
    */
     
    alert( usersMapped[0].id ) // 1
    alert( usersMapped[0].fullName ) // John Smith
    所以,实际上你需要将一个对象数组映射到另一个对象数组。在这儿尝试使用箭头函数 => 来编写。
</p>
 
<script type="text/javascript">
    'use strict';
     
    let john = { name: "John", surname: "Smith", id: 1 };
    let pete = { name: "Pete", surname: "Hunt", id: 2 };
    let mary = { name: "Mary", surname: "Key", id: 3 };
     
    let users = [ john, pete, mary ];
     
    let usersMapped = users.map( user => (
    {
        fullName : `${user.name} ${user.surname}`,
        id : user.id
    }))
     
    /*
    usersMapped = [
      { fullName: "John Smith", id: 1 },
      { fullName: "Pete Hunt", id: 2 },
      { fullName: "Mary Key", id: 3 }
    ]
    */
     
    alert( usersMapped[0].id) // 1
    alert( usersMapped[0].fullName ) // John Smith
     
     
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<p>
    请注意,在箭头函数中,我们需要使用额外的括号。
     
    我们不能这样写:
     
    let usersMapped = users.map(user => {
      fullName: `${user.name} ${user.surname}`,
      id: user.id
    });
    我们记得,有两种箭头函数的写法:直接返回值 value => expr 和带主体的 value => {...}。
     
    JavaScript 在这里会把 { 视为函数体的开始,而不是对象的开始。解决方法是将它们包装在普通括号 () 中:
     
    let usersMapped = users.map(user => ({
      fullName: `${user.name} ${user.surname}`,
      id: user.id
    }));
    这样就可以了。
</p>

  

posted on   PerfectData  阅读(225)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示