ES5数组方法
先标明参考出处: http://blog.csdn.net/codebistu/article/details/8049705
本来写过一篇有关数组新方法的(详见: [转]JavaScript函数和数组总结), 结果埋的太深找起来不方便, 在这儿专门来一篇总结下.
1. forEach
forEach(f [,o]): 此方法类似于for/in循环, 其作用是遍历整个数组并执行函数的某些操作, 但它不会遍历数组的属性. 它接受一个函数参数, 该函数可以有1,2与3个参数. 完整的三个参数分别为: 数组中的每一个值, 数组的索引, 数组本身. 这个函数没有返回值. 如:
var a = [0,1,2,3,4];
var sum = 0;
a.forEach(function(v, i, arr) {
sum += v;
console.log(arr[i]);
});
2. map
map(f [,o]): 类似于forEach()方法, 但它有返回值 --- 一个新数组, 它的参数函数必须有返回值, 参数函数的返回值作为新数组的元素. 其它用法与forEach()方法类似.
var a = [1,2,3,4,5];
var b = a.map(function(x, i, arr) {
return x*x;
}); console.log(a); // [1,2,3,4,5]
console.log(b); // [1,4,9,16,25]
3. filter
filter(f [, o]): 对数组元素进行过滤, 返回一个符合要求的新数组. 如:
var a = [1,2,3];
a[5] = 6; var b = a.filter(function(x, i, arr) {
return x !== undefined;
}); console.log(a); // [1,2,3,undefined,undefined,6]
console.log(b); // [1,2,3,6]
4. every
every(f [, o]): 有一个布尔类型的返回值, 函数参数f用来检测数组元素是否满足要求, 有且只有数组全部元素都满足f的要求 时, 才会返回true, 否则返回false.
var a = [1,3,7];
var flag = a.every(function(x, i, arr) {
return x < 5;
});
console.log(flag); // false
5. some
some(f [, o]): 与every()方法不同, 只要 有数组元素满足f的要求 就返回true, 否则返回false.
var a = [1,3,7]; var flag = a.some(function(x, i, arr) {
return x < 5;
}); console.log(flag); // true
6. reduce
reduce(f [, initial, index, array]): 对数组元素值进行计算, 返回最后一次计算的值. 函数f(x,y)接受两个参数, 如果有初始值, 则把初始值作为x计算, 然后把每一次的计算值作为下一次的x, 把数组元素依次作为y.
var a = [1,2,3,4,5]; var b = a.reduce(function(x, y) {
return x+y;
},0); // 0是初始值 console.log(b); //
7. reduceRight
reduceRight(): 与reduce()函数作用相同, 只是它从右向左依次取数组元素.
8. indexOf
indexOf(value [, start]): 根据值来找到相应在数组中的索引位置, 取多个匹配索引用最小的那个或在没有匹配的情况下返回-1.
9. lastIndexOf
lastIndexOf(value [, start]): 与indexOf()函数相似, 只是它是从后面向前面进行搜索.
ES5数组方法的更多相关文章
- ES5 数组方法map
概述 map() 方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组. 语法 array.map(callback[, thisArg]) 参数 callback 原数组中的元素经 ...
- ES5 数组方法forEach
ES6已经到了非学不可的地步了,对于ES5都不太熟的我决定是时候学习ES5了. 1. js 数组循环遍历. 数组循环变量,最先想到的就是 for(var i=0;i<count;i++)这样的 ...
- ES5 数组方法every和some
Array.prototype.every() 概述 every() 方法测试数组的所有元素是否都通过了指定函数的测试. 语法 arr.every(callback[, thisArg]) 参数 ca ...
- ES5 数组方法reduce
reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始合并,最终为一个值. 参数 callback 执行数组中每个值的函数,包含四个参数 previou ...
- 《JS权威指南学习总结--7.9 ES5中的数组方法》
内容要点: ES5中定义了9个新的数组方法来遍历.映射.过滤.检测.简化和搜索数组. 概述:首先,大多数方法的第一个参数接收一个函数,并且对数组的每个元素(或一个元素)调用一次该函数. 如果是稀疏数组 ...
- 4日6日--ES5新增数组方法
forEach使用的函数调用,所以占内存比较大,不如定长for循环和迭代for循环 1.通过forEach将数组中的元素逐个表示出来(遍历方法,读取操作). 2.通过map将原数组中的元素进行算数运算 ...
- js数组定义和方法 (包含ES5新增数组方法)
数组Array 1. 数组定义 一系列数据的集合成为数组.数组的元素可以为任何类型的数据(包括数组,函数等),每个元素之间用逗号隔开,数组格式:[1,2,3]. 2. 数组创建方式 (1) 字面量方法 ...
- ES5新增数组方法测试和字符串常见API测试
首先是ES5新增数组方法测试: <!DOCTYPE html><html lang="en"><head> <meta charset=& ...
- ES5新增方法(数组,字符串,对象)
一.数组方法 迭代(遍历)方法:forEach().map().filter().some().every(): 1. array. forEach(function(value,index,arr) ...
随机推荐
- FZYZOJ-1569 喝水
P1569 -- 喝水 时间限制:2000MS 内存限制:131072KB 状态:Accepted 标签: 无 无 无 Description GH的N个妹子要喝水, ...
- 动态规划——G 回文串
G - 回文串 Time Limit:3000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit Stat ...
- 如何解决升级WIN服务的时候,不暴力停止服务 达到升级的目的
同一个WIN服务,分别部署在A.B两台服务器上,前面使用netscaler负载均衡 ,A和B被请求频繁,几乎时时刻刻都被请求 .PS:发布WIN服务的正常流程是,停止WIN服务->发布WIN ...
- Oracle数据库操作常见异常总结
1.非法的sql语句结束符\n,抛 java.sql.SQLSyntaxErrorException: ORA-00911: 无效字符 实际就是在sql语句的结尾多了标点符号. 2.无效的序列 通常都 ...
- IOS多线程的小总结
ios中多线程的实现方案有4种 1.pthread :一套通用的多线程API/适用于Unix\Linux\Windows等系统 (跨平台可移植/使用难度大) C语言 几乎不用 ...
- Android URI简单介绍
就Android平台而言,URI主要分三个部分:scheme, authority and path.当中authority又分为host和port.格式例如以下: scheme://host:por ...
- Eclipse连接SVN服务器
(1)安装 eclipse SVN 插件 插件名称 site-1.4.8.zip Help --> SoftwareUpdates --->Find and Insta ...
- python 学习笔记 基础
python对象三要素: identity(值):对应于内存的地址,不可修改type(类型):不可修改value(值): mutable :可以修改 immutable:不可以修改 引用计数当引用计数 ...
- qt优点
(1)优良的跨平台特性. Qt支持下列操作系统:Microsoft Windows 95/98.Microsoft Windows NT.Linux.Solaris.SunOS.HP-UX.Digi ...
- android 用代码画虚线边框背景(转)
1.虚线画效果,可以使用Android中的xml来做. 2.直接上代码: <RelativeLayout android:id="@+id/coupon_popup" and ...