JavaScript 数组-Array的方法总结
JavaScript中的Array类型是经常用到的,Array类型也提供了很多方法能实现我们需求,下面我们来总结一下
一、创建Array的方法
1、使用Array构造函数
var colors=new Array();
var colors=new Array(3);//创建一个长度为3的数组
var colors=new Array("red","blue")//创建一个数组["red","blue"]
当然,上面的new可以省略不写,如 var colors=Array("red");
2、直接使用数组字面量
var colors=["red","blue","green"];
二、Array的方法1
var colors=["red","blue","green"];
1、获取数组的长度 colors.length;//3
2、访问数组第二项colors[1];//blue
3、更改数据的第二项colors[1]="black";//["red","black","green"]
4、检查是否是一个数组 colors instanceof Array;//true
5、colors.toString();//默认会以逗号隔开输出字符串 red,blue,green
6、colors.join("|");//自定义以“|”隔开输出字符串 red|blue|green
7、colors.push("brown")//往数组的尾部添加一项
8、colors.pop()//往数组的尾部删除一项
9、colors.shift()//删除数组的第一项,并取得该值
10、colors.unshift("k1","k2")//往数组的前面插入这两项;["k1","k2","red","blue","green"];
11、colors.reverse()//翻转数组的顺序
12、colors.sort()或者colors.sort([func]);
13、concat() 返回一个新数组,不影响原数组 colors.concat()或者colors.concat("k1");
14、slice(begin,end)从数组下标begin开始到end复制这个数据,不包括下标end,如果是slice(begin)那么就是从下标begin开始到数组的尾部
15、splice
splice(0,2)//从下标0开始删除数组的两项
splice(2,0,"k1","k2")从下标2开始删除0项,紧接着从这里插入两项
splice(2,1,"k1")//从下标2开始删除一项,紧接着从这里插入一项
16、indexOf("item")//从数组头开始查找某项,找到后返回下标值,找不到返回-1
17、lastIndexOf("item")//从数组尾开始查找某项,找到后返回下标值,找不到返回-1
三、Array方法2:迭代方法(ECMAScript5)
1、every():对数组的每一项运行给定的函数,每一项都返回true,则返回true(不影响原数组)
var numbers=[1,2,3,2,1];
//判断是否每个数字都大于2
var flag=numbers.every(function (item,index,array) {
return item>2;
});
2、filter():对数组中每一项运行给定的函数,返回该函数为true的项(不影响原数组)
var numbers=[1,2,3,2,1];
//返回大于2的项
var array=numbers.filter(function (item,index,array) {
return item>2;
});
3、forEach():对数组中的每一项执行给定的函数,不返回值 (不影响原数组)
var numbers=[1,2,3,2,1];
//输出每一项的平方
numbers.forEach(function (item,index,array) {
console.log(item*2);
});
4、map():对数组的每一项执行给定的函数,返回每次函数调用后结果组成的数组(不影响原数组)
var numbers=[1,2,3,2,1];
//返回每一项的平方
var array=numbers.map(function (item,index,array) {
return item*item;
});
5、some():对数组的每一项执行给定的函数,如果有一项返回true则,则返回true
var numbers=[1,2,3,2,1];
var flag=numbers.some(function (item,index,array) {
return item>2
});
三、Array方法3:归并方法(ECMAScript5)
1、reduce()方法从数组的第一行开始,逐个遍历到最后
2、reduceRight()方法从数组的最后一项开始,逐个向前遍历
var numbers=[1,2,3,4,5];
var result=numbers.reduce(function (prev,cur,index,array) {
//prev:前一个运算的结果,刚开始时候为数字的第一项
//cur:数组的当前项
//index:当前数组的下标
//array:执行这个运算的数组,当前为numbers
console.log("prev:"+prev);
console.log("cur:"+cur);
console.log("index:"+index);
console.log("array:"+array);
console.log("=============");
return prev+cur;
});
JavaScript 数组-Array的方法总结的更多相关文章
- Javascript数组Array的方法总结!
1.join() 将数组的元素组成一个字符串,以分隔符连接,如果省略则默认逗号为分隔符,该方法只接收一个参数:分隔符.此方法不会改变原数组. let arr = [1,2,3,4] let arr1 ...
- Javascript数组Array的forEach方法
Javascript数组Array的forEach扩展方法 forEach是最常用到的数组扩展方法之一,相当于参数化循环数组,它简单的在数组的每一个元素上应用传入的函数,这也意味着只有存在的元素会被访 ...
- JavaScript 数组(Array)对象的方法
JavaScript 数组(Array)对象的方法 concat() 描述:用于连接两个或多个数组.该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本. 原型:arrayObject.conc ...
- js 判断数组包含某值的方法 和 javascript数组扩展indexOf()方法
var questionId = []; var anSwerIdValue = []; ////javascript数组扩展indexOf()方法 Array.prototype.indexOf ...
- javascript数组Array强大的splice()方法
javascript的Array数组提供了强大的splice()方法, 用于对数组元素的增删改 1.删除-用于删除元素,两个参数,第一个参数(要删除第一项的位置),第二个参数(要删除的项数) 删除: ...
- JavaScript 数组(Array)方法汇总
数组(Array)常用方法; 数组常用的方法:concat(),every(), filter(), forEach(), indexOf(), join(), lastIndexOf(), map ...
- Javascript数组求和的方法总结 以及由斐波那契数列得到的启发
一次面试中,面试官要求用三种不同的Javascript方法进行一个数字数组的求和,当时思来想去只想到了使用循环这一种笨方法,因此面试比较失败,在这里总结了六种Javascript进行数组求和的方法,以 ...
- JavaScript 数组(Array)对象
Array 对象 Array 对象用于在单个的变量中存储多个值. 创建 Array 对象的语法: new Array(); new Array(size); new Array(element0, e ...
- JavaScript 数组相关基础方法
文章来源于:https://www.cnblogs.com/dolphinX/p/3353590.html 创建数组 构造函数 1.无参构造函数,创建一空数组 var a1=new Array(); ...
随机推荐
- delphi Align属性
---------------------------------------------- -
- [Todo]非常好的免费IT书籍资源 & Github排名
今天看github排名,看到排在第二位的是免费书籍: https://github.com/vhf/free-programming-books/blob/master/free-programmin ...
- nmap原理及使用方法
NMap,也就是Network Mapper,是Linux下的网络扫描和嗅探工具包. 1简介 nmap是一个网络连接端扫描软件,用来扫描网上电脑开放的网络连接端.确定哪些服务运行在哪些连接端,并且推断 ...
- Spark Streaming的PIDRateEstimator与backpressure
PIDRateEstimator是Spark Streaming用来实现backpressure的关键组件. 看了一些博客文章,感觉对它的解释都没有说到要点,还是自己来研究一下比较好. 首先,需要搞清 ...
- swift基础语法之控件使用02
//第一个控制器:显示基础控件 import UIKit class ViewController: UIViewController { var label: UILabel = UILabel() ...
- Maven+TestNG+ReportNG/Allure接口自动化测试框架初探(上)
转载:http://www.51testing.com/html/58/n-3721258.html 由于一直忙于功能和性能测试,接口自动化测试框架改造的工作被耽搁了好久.近期闲暇一些,可以来做点有意 ...
- C、C++中如何成功嵌入python
修改lib文件名称,拷贝修改C:\Python27\libs目录下原来的python27.lib为python27_d.lib 包含头文件在C:\Python27\include目录下 包含lib文件 ...
- Navicat Premium如何打开SQL文件.MDF和.LDF文件
相信大家再装SQL Server时都会遇到一件很头疼的事情--装完SQL server之后发现没有启动程序.没有经验的会以为SQL SERVER安装失败了于是选择重装.可是呵呵,重装了4,5次还是一样 ...
- Drupal的钩子系统
Drupal的很多功能都是可以定制的.以导航菜单为例,blog模块需要在菜单上添加一些功能,comment模块需要在菜单上添加一些功能,我们开发的自定义模块也需要在菜单上添加一些功能.Drupal开发 ...
- 转:maven3常用POM属性及Settings属性介绍
原文:http://blog.csdn.net/lgm277531070/article/details/6922645 A.pom.xml属性介绍: project: pom的xml根元素. par ...