ES6 Array常用方法整理

在日常编程过程中,我们总要对数组进行操作。然而使用最原始的js代码效率很低,而ES6提供了很多方法,极大的提高了我们编码的效率。

Array.prototype.forEach()

数组的遍历可以说是最常用的方法了,我们来看一下ES6的遍历方法

//句法
arr .forEach(function callback(currentValue,index,array){
    //你的迭代器
} [,thisArg ]);

参数
callback
执行每个元素的函数,采用三个参数:
currentValue
在数组中正在处理的当前元素的值。
index
在数组中正在处理的当前元素的索引。
array
forEach()正在应用的数组。
thisArg
执行时使用的值this(即参考Object)callback。
返回值
undefined。

//实例
var a = ['a', 'b', 'c'];

a.forEach(function(element) {
    console.log(element);
});

// a
// b
// c

缺点:forEach不能中断,即不能加return,break,continue。

Array .prototype .find()

find()方法返回数组中满足提供的测试功能的第一个元素的 。否则undefined返回。

//句法
arr.find(callback[,thisArg])

参数
callback
在数组中的每个值上执行的函数,取三个参数:
element
在数组中正在处理的当前元素。
index
在数组中正在处理的当前元素的索引。
array
数组find被调用。
thisArg Optional
this执行时使用的对象callback。
返回值
如果元素通过测试,则该数组中的值; 否则undefined。

//实例
function isBigEnough(element) {
  return element >= 15;
}

[12, 5, 8, 130, 44].find(isBigEnough); // 130

Array .prototype .some()

some()方法测试数组中至少有一个元素是否通过由提供的函数实现的测试。

//句法
arr .some(callback [,thisArg ])

参数
callback
测试每个元素的功能,采用三个参数:
currentValue
在数组中正在处理的当前元素。
index
在数组中正在处理的当前元素的索引。
array
数组some()被调用。
thisArg
this执行时使用的值callback。
返回值
true如果回调函数返回任何数组元素的真实值; 否则false。

//实例
function isBiggerThan10(element, index, array) {
  return element > 10;
}

[2, 5, 8, 1, 4].some(isBiggerThan10);  // false
[12, 5, 8, 1, 4].some(isBiggerThan10); // true

该方法与find有点类似,只是返回值为真假,可用于判断。

Array.prototype.map()

map()方法创建一个新数组,其结果是在调用数组中的每个元素上调用一个提供的函数。

//句法
var new_array = arr .map(function callback(currentValue,index,array){
    //返回new_array的元素
} [,thisArg ])

参数
callback
产生新数组元素的函数,取三个参数:
currentValue
在数组中正在处理的当前元素。
index
在数组中正在处理的当前元素的索引。
array
数组map被调用。
thisArg
可选的。this执行时使用的值callback。
返回值
一个新的数组,每个元素都是回调函数的结果。

//实例
var numbers = [1, 5, 10, 15];
var doubles = numbers.map(function(x) {
   return x * 2;
});
// doubles is now [2, 10, 20, 30]
// numbers is still [1, 5, 10, 15]

var numbers = [1, 4, 9];
var roots = numbers.map(Math.sqrt);
// roots is now [1, 2, 3]
// numbers is still [1, 4, 9]

注意:虽然map方法也有遍历的作用,但是不应这么做。遍历还是要用forEach。map主要还是用来返回一个与旧数组想映射的新数组。

Array .prototype .reduce ()

该reduce()方法对累加器和数组中的每个元素(从左到右)应用一个函数,将其减少为单个值。

//句法 
arr .reduce(callback [,initialValue])

参数
callback
函数在数组中的每个元素上执行,取四个参数:
accumulator
累加器累加回调的返回值; 它是上一次调用回调时返回的累积值,或者initialValue如果提供(见下文)。
currentValue
在数组中正在处理的当前元素。
currentIndex
在数组中正在处理的当前元素的索引。如果initialValue提供了索引0,则以索引1开头,否则以索引1开头。
array
数组reduce被调用。
initialValue
[可选]要用作第一个参数的值callback。如果没有提供初始值,则将使用数组中的第一个元素。在没有初始值的空数组上调用reduce是一个错误。
返回值
减少产生的价值。

//实例
var total = [0, 1, 2, 3].reduce(function(sum, value) {
  return sum + value;
}, 0);
// total is 6

var flattened = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {
  return a.concat(b);
}, []);
// flattened is [0, 1, 2, 3, 4, 5]

Array.prototype.push()

push()方法将一个或多个元素添加到数组的末尾并返回数组的新长度。

//句法
arr .push([ element1 [,... [,elementN ]]])

参数
elementN
要添加到数组末尾的元素。
返回值
length调用该方法的对象的新属性。

//实例
var numbers = [1, 2, 3];
numbers.push(4);

console.log(numbers); // [1, 2, 3, 4]

numbers.push(5, 6, 7);

console.log(numbers); // [1, 2, 3, 4, 5, 6, 7]

Array .prototype .join()

该join()方法将数组(或数组类对象)的所有元素连接到字符串中。

//句法
arr .join()
arr .join(separator)

参数
separator 可选的
指定一个字符串来分隔数组的每对相邻元素。如有必要,分隔符将转换为字符串。如果省略,则使用逗号(“,”)分隔数组元素。如果separator是一个空字符串,所有元素都将被连接,而它们之间没有任何字符。
返回值
连接了所有数组元素的字符串。如果arr.length是0,则返回空字符串。

//实例
var a = ['Wind', 'Rain', 'Fire'];
a.join();    // 'Wind,Rain,Fire'
a.join('-'); // 'Wind-Rain-Fire'

该方法可与String.split()方法配合使用。现在数组和字符串之间的相互转换。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容