这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
本文主要介绍了 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。
- 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 类似。只不过从数组右侧开始。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持 phperz!
来源: http://www.phperz.com/article/17/0528/328391.html