ECMAScript 5中对Array中新增了9个方法:

  • 5个迭代方法(循环操作数组中的各个项):forEach(),map(),filter(),every()和some()
  • 2个归并方法(迭代数组所有项,最终返回一个值):reduce()和reduceRight()
  • 2个索引方法:indexOf()和lastIndexOf()

forEach(callbackFn[,thisArg])

遍历数组一次对数组中的各个项,依次执行 callbackFn 函数,第二个可选参数则可以为这个 callbackFn 指定执行上下文。

[1, 2 ,3, 4].forEach(alert);

以上代码等同于

var array = [1, 2, 3, 4];

for (var k = 0, length = array.length; k < length; k++) {
alert(array[k]);
}
delete array[1]; // 移除 2
alert(array.length); // but the length is still 3 array.forEach(alert); // 依次弹出1、3、4
alert(array) // 1,,3,4
array[7] = 8;
alert(array.length); // 长度变为8
array.forEach(alert); // 依次弹出1、3、4、8

以上我们知道 forEach 不会循环 delete 掉的值

在这个 callbackFn 里可以使用三个参数:数组对象、元素索引以及数组本身,完整实例如下:

var sum = 0;

[1, 2, 3, 4].forEach(function (item, index, array) {
console.log(array[index] == item); // true
sum += item;
}); alert(sum); // 10

而 forEach()中的第二个参数可以改变执行上下文,实例如下:

var database = {

  users: ["Dmitry", "John", "David"],

  sendEmail: function (user) {
if (this.isValidUser(user)) {
/* sending message */
}
}, isValidUser: function (user) {
/* some checks */
} }; // send an email to every user database.users.forEach( // 在database数组内循环
database.sendEmail,
database // 使 database 对象为了执行上下文对象
);

forEach实现break功能

forEach()无法像for循环那样使用相应的break语句。在《javascript权威指南》中给出将forEach()方法放在try模块中,如能抛出异常,则会提前终止。

var array = [1, 2, 3];
function foreach(a, f, t){
try {
a.forEach(f, t);
} catch (e) {
if ( e === foreach.break ) return;
else throw e;
}
}
foreach.break = new Error('stop')
foreach(array, function(v, i, a){
console.log(v)
if ( v > 1 ) {
foreach.break;
} else {
a[i] = 0;
}
})
console.log(array) // [0, 2 , 3]

此外还可以使用变量开关,以及修改数组的方法,但是最完美的是使用以下要说到的 every 或者 some 方法

map(callbackfn[thisArg])

map()方法参数跟forEach()方法一样,此方法依次对数组中的各个元素引用callback函数,返回元素为函数结果的新的数组。

如下事例:

var arr1 = ['一','二','三','四','五','六'];
var arr2 = arr1.map(function(value, index){
return index+1;
})
console.log(arr2) // [1, 2, 3, 4, 5, 6]

ps:callbackfn 需要return ,不然数组内所有项都是 underfined

项目应用中,我们可以利用map很方便获得数组中的一些特定属性值

var users = [
{name: "Dmitry", "email": "dmitry@email.com"},
{name: "John", "email": "john@email.com"},
{name: "David", "email": "david@email.de"},
// etc
];
var emails = users.map(function (user) { return user.email; }); alert(emails); // ["dmitry@email.com", "john@email.com", "david@email.de"]

fliter(callbackfn[thisArg])

fliter()参数跟forEach()方法也一样,此方法依次对数组中的各个元素应用 callback 函数,并返回函数的返回值为 true 的元素所组成的新的数组。

接着以上 map 第一个事例,我们将筛选出数组中的偶数项目

var arr3 = arr2.filter(function(e){
return e % 2 === 0
})
console.log(arr3) //[2,4,6]

ps:返回值只要弱等于== true/false而非强等于=== true/false

some(callbackfn[thisArg])

some()方法跟forEach()方法参数是一样的,此方法依次对数组中的各个元素应用 callback 函数。如果 callback 函数的结果为true,则终止。

var found = null;

var points = [
{x: 10, y: 20},
{x: 15, y: 53},
{x: 17, y: 72}
]; points.some(function (point) { if (point.x > 10 && point.y < 60) {
found = point; // found
return true;
} return false; }); if (found) {
alert("Found: " + found.x + ", " + found.y); // Found: 15, 53
}

every(callbackfn[thisArg])

every()依次对数组中的各个元素应用 callback 函数。在 callback 返回false后终止。

跟some()的区别就是:some是找出 true 的那一样,而every则是找出 false的那一项。可以理解为 some() 要找出对的,二 every() 要找出错的。

every()方法也我们这里要介绍的数组迭代方法中的最后一个方法了,此方法参数还是跟其他迭代方法一样。

function isQualified(element, index, array) {
return (element >= 60);
}
console.log([61, 59, 81, 99, 44].every(isQualified)) // false
console.log([92, 74, 78, 88, 66].every(isQualified)) // true

reduce(callbak[, initialValue])

reduce()将数组的各个元素与之前的函数调用结果作为参数,依次调用 callback 函数,并返回函数调用的最终结果。

callbak 函数接受4个参数:前值,当前值,索引值,以及数组本身。initialValue 参数可选,表示初始值。若指定则当作第一次调用时的前值;如果没有,则使用数组的第一个元素作为前值,数组的第二个元素则是当前值。其实就是有 initialValue 比没有 initialValue 少一次操作。

var sum = [1, 2, 3, 4].reduce(function (previous, current, index, array) {
return previous + current;
},0);
console.log(sum); // 10 以上 initialValue 为 0 跟 不设置 initialValue 结果相同 var product = [1, 2, 3, 4].reduce(function (previous, current, index, array) {
return previous * current;
},1)
console.log(product) // 24 以上 缺省值 为 1 跟不设置 initialValue 结果相同

使用 reduce() 方法我们可以很轻松的将二维数组合并为一维数组:

var matrix = [
[1, 2],
[3, 4],
[5, 6]
]; alert(matrix[0][1]); // 2 // and now get the flatten array var flatten = matrix.reduce(function (previous, current) {
return previous.concat(current);
}); alert(flatten); // [1, 2, 3, 4, 5, 6]

reduceRight(callbak[, initialValue])

从数组末尾开始向前执行 reduce 操作。

indexOf(searchElement, [fromIndex])

返回第一个与 searchElement 一致的元素下标。也可以通过第2个参数来设置检索的起始下标。如果没有找到相符的结果,则返回-1

其实跟字符串的 indexOf 方法类似。

var data = [2, 5, 7, 3, 5];

alert(data.indexOf(5)); // 1
alert(data.indexOf(5, 3)); // 4 (start search from 3 index) alert(data.indexOf(4)); // -1 (not found)
alert(data.indexOf("5")); // -1 (also not found since 5 !== "5")

lastIndexOf(searchElement, [fromIndex])

从后向前检索,返回第一个与 searchElement 一直的元素的下标。也可以通过第二个参数来设置检索的起始下标。如果没有找到则返回-1

var data = [2, 5, 7, 3, 5];

alert(data.lastIndexOf(5)); // 4
alert(data.lastIndexOf(5, 3)); // 1 (start search from 3 index) if (data.indexOf(4) == -1) {
alert("4 is not found");
}

Es5很多IE9以下浏览器都不支持,所以我们在低于IE9的浏览器中加入 es5-shim

原地址:http://www.html5jscss.com/es5-array-method.html

ECMAScript 5中对Array中新增了9个方法的更多相关文章

  1. python 中 numpy array 中的维度

    简介 numpy 创建的数组都有一个shape属性,它是一个元组,返回各个维度的维数.有时候我们可能需要知道某一维的特定维数. 二维情况 >>> import numpy as np ...

  2. 关于ECMAScript 2016, 2017, 和2018中新增功能(摘抄)

    ECMAScript 2016 1. Array.prototype.includes includes是数组上的简单实例方法,并有助于轻松查找某个项是否在Array中(包括NaN不像indexOf) ...

  3. JavaScript中的Array数组详解

    ECMAScript中的数组与其他多数语言中的数组有着相当大的区别,虽然数组都是数据的有序列表,但是与其他语言不同的是,ECMAScript数组的每一项可以保存任何类型的数据.也就是说,可以用数组的第 ...

  4. 详解Javascript中的Array对象

    基础介绍 创建数组 和Object对象一样,创建Array也有2种方式:构造函数.字面量法. 构造函数创建 使用构造函数的方式可以通过new关键字来声明,如下所示: 12 var arr = new ...

  5. ES5新特性:理解 Array 中增强的 9 个 API

    为了更方便的对JS中Array进行操作,ES5规范在Array的原型上新增了9个方法,分别是forEach.filter.map.reduce.reduceRight.some.every.index ...

  6. JavaScript中数组Array方法详解

    ECMAScript 3在Array.prototype中定义了一些很有用的操作数组的函数,这意味着这些函数作为任何数组的方法都是可用的. 1.Array.join()方法 Array.join()方 ...

  7. 了解PHP中的Array数组和foreach

    1. 了解数组 PHP 中的数组实际上是一个有序映射.映射是一种把 values 关联到 keys 的类型.详细的解释可参见:PHP.net中的Array数组    . 2.例子:一般的数组 这里,我 ...

  8. 转OSGchina中,array老大的名词解释

    转OSGchina中,array老大的名词解释 转自:http://ydwcowboy.blog.163.com/blog/static/25849015200983518395/ osg:: Cle ...

  9. C#中数组Array、ArrayList、泛型List<T>的比较

    在C#中数组Array,ArrayList,泛型List都能够存储一组对象,但是在开发中根本不知道用哪个性能最高,下面我们慢慢分析分析. 一.数组Array 数组是一个存储相同类型元素的固定大小的顺序 ...

随机推荐

  1. zabbix使用之常用功能使用心得

    ZABBIX 使用 Written by: Jane.Hoo 1.zabbix监控概念介绍 项目(iterm)定义收集被监控的数据项,如收集被监控机内存使用情况 应用集(application)一些项 ...

  2. IT开发工程师的悲哀现状和可能前途

    IT开发工程师的悲哀现状和可能前途 本文所指的开发工程师,仅指程序开发人员和以数字电路开发为主的电子工程师.当你选择计算机或者电子.自控等专业进入大学时,你本来还是有机会从事其它行业的,可你毕业时执迷 ...

  3. 002-java语言基础

    一.安装卸载 卸载:控制面板 安装:下载对应版本 注意1.安装路径→尽量不要有空格和汉字 注意2.安装之后,jre可以不用安装,jdk中含有 二.环境变量 环境变量:理解,一些快捷路径.方便快速查找应 ...

  4. Oracle DB 使用RMAN将数据库移植到ASM存储区

    1. 完全关闭数据库. 2. 关闭数据库并修改服务器参数文件,以使用Oracle Managed Files (OMF). 3. 编辑并执行以下RMAN 脚本: STARTUP NOMOUNT; RE ...

  5. SCADA必备函数 实际测试。

    一:GetTickCount() 综述: 这是一个Window的平台的API函数, 所以啊 在 MFC中 他的前面有两个冒号,像个和尚一样. 所以它不会受限于类,可以在MFC中任意位置使用. 这个函数 ...

  6. CodeChef - COUNTARI Arithmetic Progressions (FFT)

    题意:求一个序列中,有多少三元组$(i,j,k)i<j<k $ 满足\(A_i + A_k = 2*A_i\) 构成等差数列. https://www.cnblogs.com/xiuwen ...

  7. Python Date 1–Hello world print

    对比学习Python与C str1 = 'hello python 2'# 字符串i = 3.1415926535 print(str1)print("hello python\n" ...

  8. 关于axios

    简介 axios是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中 主要是用于向后台发起请求的,还有在请求中做更多是可控功能. 特点 从浏览器中创建 XMLHttpRe ...

  9. 延迟环境变量扩展(bat)

    延迟环境变量扩展(bat) 之前遇到一些环境变量的问题,简单记录下 From:http://www.cnblogs.com/dongzhiquan/archive/2012/09/05/2671218 ...

  10. RocEDU.阅读.写作《霍乱时期的爱情》书摘(一)

    不可避免,苦杏仁的香味总是让他想起爱情受阻后的命运. 一切都显得凄凉无助,可那一间间肮脏的小酒馆里却传来震耳欲聋的鼓乐声,那是穷人的狂欢,既无涉上帝,也无涉圣神降临节的诫命. 他们经常谈起它,一同承受 ...