JS中Array数组学习总结


Posted in Javascript onJanuary 18, 2017

引用类型分为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类似。只不过从数组右侧开始。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JQuery为textarea添加maxlength属性的代码
Apr 07 Javascript
JavaScript 放大镜 移动镜片效果代码
May 09 Javascript
新手快速学习JavaScript免费教程资源汇总
Jun 25 Javascript
javascript中$(function() {});写与不写有哪些区别
Aug 10 Javascript
深入理解$.each和$(selector).each
May 15 Javascript
Ajax实现不刷新取最新商品
Mar 01 Javascript
angularjs指令之绑定策略(@、=、&amp;)
Apr 13 Javascript
Node.js+jade抓取博客所有文章生成静态html文件的实例
Sep 19 Javascript
你可能不知道的前端算法之文字避让(inMap)
Jan 12 Javascript
Angular ng-animate和ng-cookies用法详解
Apr 18 Javascript
layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
Sep 21 Javascript
详解React路由传参方法汇总记录
Nov 29 Javascript
原生javascript实现图片放大镜效果
Jan 18 #Javascript
jQuery Validation Engine验证控件调用外部函数验证的方法
Jan 18 #Javascript
原生js实现回复评论功能
Jan 18 #Javascript
js实现表格筛选功能
Jan 18 #Javascript
js放大镜放大购物图片效果
Jan 18 #Javascript
详解vue 中使用 AJAX获取数据的方法
Jan 18 #Javascript
easyui 中的datagrid跨页勾选问题的实现方法
Jan 18 #Javascript
You might like
汉字转化为拼音(php版)
2006/10/09 PHP
如何过滤高亮显示非法字符
2006/10/09 PHP
在线短消息收发的程序,不用数据库
2006/10/09 PHP
浅谈php和.net的区别
2014/09/28 PHP
thinkPHP5.0框架简单配置作用域的方法
2017/03/17 PHP
php设计模式之观察者模式实例详解【星际争霸游戏案例】
2020/03/30 PHP
dojo 之基础篇(二)之从服务器读取数据
2007/03/24 Javascript
用javascript实现读取txt文档的脚本
2007/07/20 Javascript
JavaScript 学习笔记二 字符串拼接
2010/03/28 Javascript
JQuery从头学起第一讲
2010/07/04 Javascript
js null,undefined,字符串小结
2010/08/21 Javascript
js对象转json数组的简单实现案例
2014/02/28 Javascript
js定时器(执行一次、重复执行)
2014/03/07 Javascript
JavaScript设计模式之单例模式实例
2014/09/24 Javascript
jQuery的框架介绍
2016/05/11 Javascript
JS实现图片剪裁并预览效果
2016/08/12 Javascript
JS中script标签defer和async属性的区别详解
2016/08/12 Javascript
JavaScript提高加载和执行效率的方法
2017/02/03 Javascript
使用Webpack提高Vue.js应用的方式汇总(四种)
2017/07/10 Javascript
微信小程序实现漂亮的弹窗效果
2020/05/26 Javascript
详解Element 指令clickoutside源码分析
2019/02/15 Javascript
javascript实现导航栏分页效果
2019/06/27 Javascript
JS+Canvas实现五子棋游戏
2020/08/26 Javascript
[01:27:43]VGJ.S vs TNC Supermajor 败者组 BO3 第三场 6.6
2018/06/07 DOTA
[43:18]NB vs Infamous 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.22
2019/09/05 DOTA
Python第三方库的安装方法总结
2016/06/06 Python
python如何修改装饰器中参数
2018/03/20 Python
浅谈django rest jwt vue 跨域问题
2018/10/26 Python
终于搞懂了Keras中multiloss的对应关系介绍
2020/06/22 Python
python判断变量是否为列表的方法
2020/09/17 Python
建筑专业自荐信
2013/10/18 职场文书
金融学专业大学生职业生涯规划
2014/03/07 职场文书
社区先进事迹材料
2014/05/19 职场文书
教师节倡议书
2014/08/30 职场文书
详解如何在Canvas中添加事件的方法
2021/04/17 Javascript
Windows Server 2012配置DNS服务器的方法
2022/04/29 Servers