JS中Array数组学习总结

那么,数组是干啥的呢?在我看来,它是用来保存数据的。

一、声明一个数组:

1、构造函数 var colors=new Array();简写的话可以省略new,即var colors=Array();

2、数组字面量 var colors=["black","green","pink"];

二、读取和设置数组的值:

读取:colors[x];参数x为0~colors.length-1;

设置的话直接给colors[x]=进行赋值就好,这样会覆盖之前的数值哦;

三、在这里简单说说length的用法:

colors.length获取数组的长度,也可以说是数组有几项,如果说一个数组有7项,但是你写入了colors.length=2,那么就会删除后面的5项;

利用length属性也可以为数组最后添加数据:colors[colors.length]=进行赋值;

四、数组中的操作:

方法   作用   返回值  
Array.push(x,y,z)   把xyz添加到数组末尾   新数组长度  
Array.pop()   移除数组最后一项   移除的最后一项  
Array.shift()   移除数组第一项   移除的第一项  
Array.unshift(a,b,c)   在数组前端添加a,b,c   新数组长度  
Array.reverse()   反转数组   反转后的新数组  
Array.sort()   对数组中每一项的字符串进行升序排列   重新排序后的数组  
Array.concat(a,b,c)   连接数组   返回连接好的新数组  
Array.slice(1,n)   截取数组,从1到n,1和n为索引值   返回截取的数组(在这里返回从1开始,到n之前结束)  
Array.indexOf(a,start)   查找a的所在的位置,从start开始   返回a所在的索引值,如果没有查找到则返回-1  
Array.lastIndexOf(a,atart)   与indexOf相反,lastIndexOf从末尾开始查找   返回a所在的索引值,如果没有查找到则返回-1  

splice()方法单拿出来说说。为什么单拿出来?因为牛逼;

1.删除。接受两个参数:要删除第一项的位置和要删除的项数;

例:splice(1,2),就是要删除数组种的2,3项;

2.插入。接受三个参数:起始位置,0,要插入的项。

例:splice(2,0,"red","green"),会在数组索引值为2的位置插入red和green。

3.替换。接受三个参数:起始位置,要删除的项数,要插入的项。

例:splice(2,1,"red","green"),删除索引值为2这一项,添加red和green。

tips:sort()用法实例:按升序排列数组 function compare(val1,val2){ if(val1<val2){ return -1; }else if(val1>val2){ return 1; }else{ retuen 0 } } var num=[0,2,9,3,1]; num.sort(compare); alert(num);//0,1,2,3,9

 五。数组中的迭代方法

1.every()和some():

查询数组中的每一项是否满足条件,如果每一项都返回true,则result返回true。 var numbers=[0,1,2,3,4]; var result=numbers.every(function(item,index,array){ return (item>2) }) alert(result);//false 查询数组中的每一项是否满足条件,如果有一项都返回true,则result返回true。 var numbers=[0,1,2,3,4]; var result=numbers.some(function(item,index,array){ return (item>2) }) alert(result);//true

2.filter():

该方法会返回结果为true的项组成的数组;

3.map():

var result=numbers.map(function(item,index,array){ return item*2; })

返回数组执行完参数之后的新数组。

六、归并

Array.reduce()

var numbers=[1,2,3,4,5]; var sum=numbers.reduce(function(prev,cur,index,array){ return prev+cur }) alert(sum);

在上个例子中,reduce()接受四个参数,第一个参数是数组的第一项,第二个参数是数组的第二项;

第一次执行函数,prev是1,cur是2,第二次执行,prev是3(1+2的结果),cur是3。

Array.reduceRight()。和reduce类似。只不过从数组右侧开始。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwddyp.html