详解javascript,ES5标准中新增的几种高效Array操作方法
1、js中常用的数组Array对象属性:
如图,其中用红色圆圈标记的部分,为ES5新增的属性。
2、浏览器支持情况:
- IE:9+;
- Chrome;
- Firefox2+;
- Safari 3+;
- Opera 9.5+;
3、位置方法
var numbers = [,,,,,,,,];
alert(numbers.indexOf()); //
alert(number.lastIndexOf()); //
alert(number.indexOf(,)); //
alert(number.lastIndexOf(,)); //3
4、迭代方法
ECMAScript5为数组定义了5个迭代方法。
4.1、every()
定义和用法:every() 方法用于检测数组所有元素是否都符合指定条件(通过函数提供)。
every() 方法使用指定函数检测数组中的所有元素:
- 如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。
- 如果所有元素都满足条件,则返回 true。
注意: every() 不会对空数组进行检测。
注意: every() 不会改变原始数组。
描述:检测数组 ages 的所有元素是否都大于 18 :
var ages = [, , , ];
function checkAdult(age) {
return age >= ;
}
function myFunction() {
document.getElementById("demo").innerHTML = ages.every(checkAdult);
}
结果为:
false;
4.2、some()
定义和用法:some() 方法用于检测数组中的元素是否满足指定条件(函数提供)。
对数组中的每一项运行给定的函数,如果该函数对任一项都返回true,则返回true;
代码如下:
var numbers = [,,,,,,,,];
var someResult = numbers.some(function(item,index,array){//item指代数组值;index指代数组下标;array指代数组本身;
return (item>);
});
alert(someResult);
结果为:
true;
4.3、filter()
var numbers = [,,,,,,,,];
var filterResult = numbers.filter(function(item,index,array){//item指代数组值;index指代数组下标;array指代数组本身;
return (item>);
});
alert(filterResult );
结果为:
[,,,,]
4.4、map()
var numbers = [,,,,,,,,];
var mapResult = numbers.map(function(item,index,array){//item指代数组值;index指代数组下标;array指代数组本身;
return item*;
});
alert(mapResult );
结果为:
[,,,,,,,,]
4.5、forEach()
var numbers = [,,,];
numbers.forEach(function(item,index,array){
console.log(item);
});
结果为:
5、缩小方法
var values = [,,,,];
var sum =values.reduce(function(prev,cur,index,array){
return prev+cur;
});
alert(sum);
结果为:
详解javascript,ES5标准中新增的几种高效Array操作方法的更多相关文章
- 详解javascript,ES5标准中新增的几种高效Object操作方法
1.Object 对象 (JavaScript) 提供对所有 JavaScript 对象通用的功能.参考网站:https://msdn.microsoft.com/zh-cn/library/kb6t ...
- 详解JavaScript数组过滤相同元素的5种方法
详解JavaScript数组过滤相同元素的5种方法:https://www.jb51.net/article/114490.htm
- 【转】详解JavaScript中的this
ref:http://blog.jobbole.com/39305/ 来源:foocoder 详解JavaScript中的this JavaScript中的this总是让人迷惑,应该是js众所周知的坑 ...
- (转载)详解Javascript中prototype属性(推荐)
在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不存在类(Class)的概念的,javascript中不 ...
- 详解 javascript中offsetleft属性的用法(转)
详解 javascript中offsetleft属性的用法 转载 2015-11-11 投稿:mrr 我要评论 本章节通过代码实例介绍一下offsetleft属性的用法,需要的朋友可以做一 ...
- 详解javascript中的this对象
详解javascript中的this对象 前言 Javascript是一门基于对象的动态语言,也就是说,所有东西都是对象,一个很典型的例子就是函数也被视为普通的对象.Javascript可以通过一定的 ...
- js对象详解(JavaScript对象深度剖析,深度理解js对象)
js对象详解(JavaScript对象深度剖析,深度理解js对象) 这算是酝酿很久的一篇文章了. JavaScript作为一个基于对象(没有类的概念)的语言,从入门到精通到放弃一直会被对象这个问题围绕 ...
- 详解javascript的类
前言 生活有度,人生添寿. 原文地址:详解javascript的类 博主博客地址:Damonare的个人博客 Javascript从当初的一个"弹窗语言",一步步发展成为现在前后端 ...
- 详解Javascript的继承实现(二)
上文<详解Javascript的继承实现>介绍了一个通用的继承库,基于该库,可以快速构建带继承关系和静态成员的javascript类,好使用也好理解,额外的好处是,如果所有类都用这种库来构 ...
随机推荐
- List<T>保存为XML文件
今天我们学习怎样把List<T>写成一个XML文件保存起来.因为我们在做动态网站开发时,需要对一些不太常变化的数据产生为XML文件,让程序直接去读取,而不是每次是SQL数据库取. 为了解决 ...
- 基于<MediaElement>的WPF视频播放器(可拖拽进度条播放)【1】
一.前言 前两天上峰要求做一个软件使用向导,使用WPF制作.这不,这两天从一张白纸开始学起,做一个播放演示视频的使用向导.以下是粗设计的原型代码: 二.效果图 三.代码 前台代码: < ...
- QT TableWidget 应用笔记
QT TableWidget应用笔记 分类: QT2013-05-21 16:22 2561人阅读 评论(0) 收藏 举报 1.设置表头及大小 QStringList header; header&l ...
- 背水一战 Windows 10 (6) - 控件 UI: 字体的自动继承的特性, Style, ControlTemplate
[源码下载] 背水一战 Windows 10 (6) - 控件 UI: 字体的自动继承的特性, Style, ControlTemplate 作者:webabcd 介绍背水一战 Windows 10 ...
- LeetCode4:Add Two Numbers
题目: You are given two linked lists representing two non-negative numbers. The digits are stored in r ...
- hibernate---注解--CascadeType属性
cascade表示级联操作 CascadeType.MERGE级联更新:若items属性修改了那么order对象保存时同时修改items里的对象.对应EntityManager的merge方法 Cas ...
- Scalaz(45)- concurrency :Task-函数式多线程编程核心配件
我们在上一节讨论了scalaz Future,我们说它是一个不完善的类型,最起码没有完整的异常处理机制,只能用在构建类库之类的内部环境.如果scalaz在Future类定义中增加异常处理工具的话,用户 ...
- 泛函编程(26)-泛函数据类型-Monad-Applicative Functor Traversal
前面我们讨论了Applicative.Applicative 就是某种Functor,因为我们可以用map2来实现map,所以Applicative可以map,就是Functor,叫做Applicat ...
- python队列Queue
Queue Queue是python标准库中的线程安全的队列(FIFO)实现,提供了一个适用于多线程编程的先进先出的数据结构,即队列,用来在生产者和消费者线程之间的信息传递 基本FIFO队列 clas ...
- Atitit. 获取cpu占有率的 java c# .net php node.js的实现
Atitit. 获取cpu占有率的 java c# .net php node.js的实现 通过wmic接口获取cpu占有率 C:\Users\Administrator.ATTILAXPC188&g ...