Rumah >hujung hadapan web >tutorial js >Js中Array数组学习总结
第一次写博客。。。有点方。。。
小白一枚(是真的小白),自学前端,下面来说说我在学习过程中总结的一些数组操作,如果说哪有错误,请各位大神多多指出,小的虚心接受。
引用类型分为Object类型(所谓的对象),Array类型(本文谈的数组),Function类型等。
那么,数组是干啥的呢?在我看来,它是用来保存数据的。
一、声明一个数组:
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。
(val181f0d8c0f18b4c7f4121119843be84c9 10
五。数组中的迭代方法
1.every()和some():
numbers=[0,1,2,3,4 result=numbers.every( (item>2 numbers=[0,1,2,3,4 result=numbers.some( (item>2
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类似。只不过从数组右侧开始。
以上就是Js中Array数组学习总结 的内容,更多相关内容请关注PHP中文网(www.php.cn)!