数组API(2)
ES5中数组新增API:
1. indexOf
作用:检测当前数据是否在数组中存在;
特点:如果存在返回相对应的下标,如果不存在则返回-1;
如果数组中存在多个需要判断的这个数据,则返回最近的这个数据的下标;
可以传递两个参数,第二个参数指定查询的起始位置;
示例:
var arr = [10,20,30,40,50,30];
var index1= arr.indexOf(30);
var index2 = arr.indexOf(80);
var index3 = arr.indexOf(30,3);
console.log(index1); //结果为2
console.log(index2); //结果为-1
console.log(index3); //结果为5
2. lastIndexOf
作用:检测当前数据是否在数组中存在;
特点:如果存在返回相对应的下标,如果不存在则返回-1;
如果数组中存在多个需要判断的这个数据,则返回最后的这个数据的下标(也就是说它的查找方式是从右往左);
可以传递两个参数,第二个参数是指定查询的起始位置,然后从起始位置往左找;
示例:
var arr = [10,20,30,40,50,30];
var index1= arr.lastIndexOf(30);
var index2 = arr.indexOf(80);
var index3= arr.lastIndexOf(30,5);
console.log(index1); //结果为5
console.log(index2); //结果为-1
console.log(index3); //结果为5
3. map
作用:需要对数组中的数据做一些同一类型的操作时,可以用到map;
特点:不会改变原数组,会有一个返回值, 返回值是一个新的数组;
map中除了有一个回调以外,还有第二个参数就是用来改变this指向的,此参数选用。
回调函数中的3个参数:
item:数组中的数据
index:数组中数据的下标
array:当前遍历的数组
示例:
var arr = [10,20,30,40,50];
var newArr = arr.map(function(item,index,array){
console.log(item,index,array);//自己可以打印着看看
return item*=1.3;
})
console.log(arr); // [10,20,30,40,50]
console.log(newArr); // [ 13, 26, 39, 52, 65 ]
4. forEach
作用:遍历;
特点:没有返回值,不会改变原数组;
forEach中除了有一个回调以外,还有第二个参数 就是用来改变this指向的,此参数选用。
回调函数中的3个参数:
item:数组中的数据
index:数组中数据的下标
array:当前遍历的数组
示例:
var arr = [10,20,30,40,50];
var newArr = []
arr.forEach(function(item,index,array){
newArr.push(item*=1.3);
console.log(this);//当前this指向document,如果不改变this指向,则指向window
},document)
console.log(arr);// [10,20,30,40,50]
console.log(newArr);//[ 13, 26, 39, 52, 65 ]
注:forEach和map是不能被终止的 也就是说return 和break根本不会终止它们的循环
5. filter
作用:通过某种条件对数据进行过滤筛选;
特点:返回一个匹配过滤条件的新数组,不会改变原数组;
filter中除了有一个回调以外,还有第二个参数 就是用来改变this指向的,此参数选用。
回调函数中的3个参数:
item:数组中的数据
index:数组中数据的下标
array:当前遍历的数组
示例:
var arr = [10,20,30,40,50];
var newArr = arr.filter(function(item,index,array){
console.log(this);//当前this指向document,如果不改变this指向,则指向window
return item>30;
},document)
console.log(arr);// [10,20,30,40,50]
console.log(newArr);//[ 40,50 ]
6. reduce
作用: 累积器;
特点:返回一个匹配过滤条件的新数组,不会改变原数组;
回调函数中的4个参数:
init:初始值,值为reduce函数的第二个参数
current: 为数组中的当前值, 第一次为数组中下标为0的这个值 第二次为下标1的值 .....
index:数组中数据的下标
array:当前遍历的数组
示例:
var arr = [10,20,30,40,50];
var sum = arr.reduce(function(init,current){
return current-init;
},0)
console.log(sum);//30 ;sum的计算过程: sum=50-(40-(30-(20-(10-0))));
7.reduceRight
作用同reduce,唯一的不同是,reduceRight 是从右至左遍历数组的元素。
8.some
作用: 测试数组中是否有某元素通过 callback 函数测试;
特点:如果 callback 函数返回值为 true 则表示通过测试(有一个通过测试,则为真);
回调函数中的3个参数:
v:数组中的数据
i:数组中数据的下标
arr:当前遍历的数组
let arr=[1,3,6,4,2]
let someRes = arr.some((v, i, arr) => {
return v > 5
})
console.log(someRes) ;// true
9. every
作用: 测试数组中是否全部元素通过 callback 函数测试;
特点:如果 callback 函数返回值为 true 则表示通过测试(全部通过测试,则为真);
回调函数中的3个参数:
v:数组中的数据
i:数组中数据的下标
arr:当前遍历的数组
let arr=[1,3,6,4,2]
let everyRes = arr.every((v, i, arr) => {
return v > 5
})
console.log(everyRes) ;// false
数组API(2)的更多相关文章
- javascript_core_10之继承与数组API
1.现有两对象间的继承:Object.setPrototypeOf(child,father): 2.基于现有父对象创建子对象:var child=Object.create(father,{新属性} ...
- javascript_core_04之数组API
1.数组API——splice: ①删除:var deletes=arr.splice(starti,n):删除starti位置开始的n个,返回删除元素组成的临时数组: ②插入:arr.splice( ...
- 数组Array、数组API
1.数组:批量管理多个数据的存储空间. 数组的作用:现实中,批量管理多个数据都是集中分组存放,良好的数据结构,可极大提高程序的执行效率! 优点:方便查找 2.创建数组:(4种方式) (1)var 变量 ...
- JavaScript中对数组和数组API的认识
JavaScript中对数组和数组API的认识 一.数组概念: 数组是JavaScript中的一类特殊的对象,用一对中括号“[]”表示,用来在单个的变量中存储多个值.在数组中,每个值都有一个对应的不重 ...
- 数组API汇总
数组API汇总 Javascript数组API: 1.将数组转化为字符串:2种: 1.var str=String(str); 将数组转化为字符串并分隔每个元素; var arr=[1,2,3]; ...
- 数组Api .map()的使用
之前并没有过多的使用过这个Api,在此记录下对其的理解,方便以后多多使用. 首先是对map的说明: var mappedArray = array.map(callback[, thisObject] ...
- Javascript之高级数组API的使用实例
JS代码中我们可以根据需求新建新的对象解决问题的同时,也有一些常用的内置对象供我们使用,我们称之为API,本篇文章只是对数组部分进行了练习. 例一:伪数组,不能修改长短的数组(所以没办法清零),可以修 ...
- js 数组api
Javascript Array API JS数组对象提供了很多API方法,要用到的朋友可以查阅哈,如有错误欢迎指正. /** * Created by Administrator on 2017 ...
- js手写数组Api--模拟实现常见数组Api
数组的API经常用,但是api的内部实现还没研究过,于是就研究学习了下. 原文地址: https://www.cnblogs.com/yalong/p/11606865.html 数组的API的具体使 ...
随机推荐
- Python基础-random模块及随机生成11位手机号
import random # print(random.random()) # 随机浮点数,默认取0-1,不能指定范围# print(random.randint(1, 20)) # 随机整数,顾头 ...
- 第二章 python基础(二)
第九节 函数 函数就是完成特定功能的一个语句组,这组语句可以作为一个单位使用,并且给它取一个名字. 可以通过函数名在程序的不同地方多次执行(这通常叫做函数调用),却不需要在所有地方都重复编写这些语句. ...
- 5_Singleton 游戏开发中的单例模式
强制类只有一个实例 提供全局的访问 ###为什么使用: ``` 如果没有地方访问这个类,则不会创建实例 静态类在main之前实例化, 可以尝试Lazy initialization 派生单例类, 获得 ...
- cocos2d-x CSV文件读取 (Excel生成csv文件)
实现类 CCSVParse.h #ifndef __C_CSV_PARSE__ #define __C_CSV_PARSE__ #include "cocos2d.h" #incl ...
- 【二叉树的递归】05二叉树中找任意起点和终点使他们的路径和最大【Binary Tree Maximum Path Sum】
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 给定一个二叉树,寻找值最大的路径. ...
- DEBUG命令详细说明
启动DEBUG 1.打开Windows命令窗口 在Windows 95/98的环境中,打开命令窗口的步骤为:点击“开始”→“运行”,输入“command”命令: 在WindowsXP及WIN7的环境中 ...
- POJ2420:A Star not A Tree?
我对模拟退火的理解:https://www.cnblogs.com/AKMer/p/9580982.html 我对爬山的理解:https://www.cnblogs.com/AKMer/p/95552 ...
- Ajax效果--个人收藏
$.ajax({ url: "../../../Tools/WeChatMenu.ashx?action=get_menu", type: "post", da ...
- VMware里Ubuntu-16.04-desktop的VMware Tools安装图文详解
不多说,直接上干货! 总的来说,根据分为三个步骤. 步骤一: 点击 :虚拟机—–>安装VM tools 然后发现桌面会跳出如下问题: 客户机操作系统已将 CD-ROM 门锁定,并且可能正在使用 ...
- Java探索之旅(15)——包装类和字符类
1.包装类 ❶出于对性能的考虑,并不把基本数据类型作为对象使用,因为适用对象需要额外的系统花销.但是某些Java方法,需要对象作为参数,例如数组线性表ArrayList.add(Object).Jav ...