在JavaScript中,当在map内调用函数时使用'this',它指向当前正在被遍历的数组元素。
在JavaScript中,map()是一个数组方法,用于创建一个新数组,该数组的元素是原始数组经过函数处理后的结果。在map()方法中,可以传递一个函数作为参数,该函数将被应用于数组的每个元素。
当在map内部调用函数时,可以使用'this'关键字来引用当前正在被遍历的数组元素。这对于需要在函数内部访问当前元素的属性或方法非常有用。
下面是一个示例,演示如何在map内部使用'this'关键字:
const fruits = [
{ name: 'apple', color: 'red' },
{ name: 'banana', color: 'yellow' },
{ name: 'grape', color: 'purple' }
];
const fruitNames = fruits.map(function() {
return this.name;
});
console.log(fruitNames);
// 输出: ["apple", "banana", "grape"]
在上面的示例中,我们定义了一个包含水果对象的数组。然后,我们使用map()方法创建了一个新数组fruitNames,其中包含了每个水果对象的名称。在map()方法的回调函数中,我们使用'this.name'来引用当前正在被遍历的水果对象的名称。
需要注意的是,当使用箭头函数时,它们没有自己的'this'绑定,而是继承了外部作用域的'this'。因此,在箭头函数中使用'this'时,它将引用外部作用域的'this',而不是当前正在被遍历的数组元素。
推荐的腾讯云相关产品和产品介绍链接地址:
领取专属 10元无门槛券
手把手带您无忧上云