Rumah  >  Artikel  >  hujung hadapan web  >  JavaScript中进行数组处理的map()方法的使用方法分析

JavaScript中进行数组处理的map()方法的使用方法分析

不言
不言asal
2019-01-09 15:25:397084semak imbas

本篇文章将给大家介绍关于处理数组数据的map()方法的用法以及map()方法与forEach语句的区别,内容很详细,下面我们来看具体的内容。

JavaScript

首先我们来看一下map()的基本语法

var array = [ 数组数据 ];
array.map(回调函数);

Map是用于数组数据的方法,可以为每个元素执行“回调函数” 并将结果作为新数组返回。

换句话说,通过在此函数中编写要执行的进程,您可以对数组的每个元素执行任何操作!

如何使用map方法迭代数组?

以下示例是对包含数字数据的数组使用map方法的示例

var items = [1,2,3,4,5];
 
var result = items.map(function( value ) {
    return value * 2;
});
console.log( result );

输出结果如下

JavaScript中进行数组处理的map()方法的使用方法分析

在该示例中,对于数值“1到5”的数组用回调函数执行对每个元素进行加倍的处理。

出于这个原因,我们分配一个数组,其结果翻2倍作为“result ”的返回值,因此可以看到输出结果都变成了其本身的2倍。

最初,它都是使用for语句或while语句编写循环,但使用map非常方便,因为它可以通过一个非常简单的程序来实现!

在JavaScript中还有一个与map()方法用法类似的reduce()方法,关于reduce()方法可以参考这篇文章:JavaScript中的reduce如何使用

关于reduce()和map()方法的区别可以参考这篇文章:JavaScript中map()和reduce()有什么区别

map()与forEach语句的区别?

map()类似于forEach语句,它可以以相同的方式操作数组。

我们来看具体的示例

//forEach
[1,2,3].forEach(function( value ) {
   console.log( value );
});
 
 
//map
[1,2,3].map(function( value ) {
    console.log( value );
});

输出结果是一样的都为

JavaScript中进行数组处理的map()方法的使用方法分析

正如您在此示例中看到的,forEach和map获得的结果是相同的。

那么,它们有什么不同,最大一点的不同就是是否具有返回值。

换句话说,forEach只是一种执行方法,而map在执行后将结果作为数组数据返回。

我们具体看示例

forEach:

var result = [1,2,3].forEach(function( value ) {
 
    return value * 2;
 
});
 
console.log( result );

输出结果如下为:

微信截图_20190109144506.png

forEach的返回值看不到。

map:

var result = [1,2,3].map(function( value ) {
 
    return value * 2;
 
});
 
console.log( result );

输出结果为

微信截图_20190109144722.png

可以将数组数据作为执行结果返回。

map的回调函数

之前我们看回调函数只有一个参数,但实际上你可以用得到有三个参数!

数组数据.map( function( value, index, array ) {

});

Value是数组的值

index是数组的索引号

array是当前正在处理的数组

例如,在下面的示例中,我们将使用参数index,将index号的值为偶数的值翻倍

var items = [1,2,3,4,5,6,7,8,9];
var result = items.map( function( value, index, array ) {
    if( index % 2 !== 0 ) {
        return value * 2;
    }
    else {
        return value;
    }
});
console.log( result );

输出结果如下

微信截图_20190109145948.png

此外,map具有不对原始数组数据进行任何更改的功能,但如果使用第三个参数array ,则还可以更改原始数据!

var items = [1,2,3,4,5,6,7,8,9];
 
items.map( function( value, index, array ) {
 
    array[index] = value * 2;
 
});
 
console.log( items );

输出结果如下

微信截图_20190109150800.png

在过去,“回调函数”被指定为“map”的第一个参数,但实际上你可以指定任意“对象”作为第二个参数!

var array = [ 数组数据 ]; 
//指定对象为第2个参数
array.map( 回调函数, 对象 );

这使得可以组合指定的数组和对象以实现更方便的编程。

例如,在下面的示例中,将食物简单对象foodList指定为map的第二个参数。

var foodList = {
  '苹果': 45,
  '哈密瓜': 50,
  '猕猴桃': 60,
  '草莓': 40
};
数组.map( function( value ) {
 
}, foodList );

我们从对象中指定任意关键字并返回“price”。

var foodList = {
  '苹果': 45,
  '哈密瓜': 50,
  '猕猴桃': 60,
  '草莓': 40
};
var order = ['草莓', '猕猴桃'];
var result = order.map( function( value, index, array ) {
    return this[value];
 
}, foodList );
console.log( result );

输出结果如下

微信截图_20190109151827.png

在此示例中,您可以看到关键字在数组order中设置,从中获取与对象中拥有的关键字匹配的“price”并将其作为数组返回。

Atas ialah kandungan terperinci JavaScript中进行数组处理的map()方法的使用方法分析. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn