引用类型分为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类似。只不过从数组右侧开始。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js Array数组
# JavaScript中Array方法你该知道的正确打开方法
# JavaScript引用类型Array实例分析
# JavaScript中利用Array filter() 方法压缩稀疏数组
# javascript中new Array()和var arr=[]用法区别
# JS中去掉array中重复元素的方法
# javascript 中关于array的常用方法详解
# JavaScript中数组Array.sort()排序方法详解
# JavaScript中数组Array方法详解
# 详解js中Array的方法及技巧
# 组中
# 移除
# 每一项
# 升序
# 在这里
# 第一项
# 如果没有
# 拿出来
# 值为
# 这一
# 就会
# 第一个
# 就好
# 会在
# 它是
# 也可
# 第二个
# 如果说
# 上个
# 在我看来
相关文章:
家庭服务器如何搭建个人网站?
建站之星如何快速解决建站难题?
如何快速打造个性化非模板自助建站?
如何在建站主机中优化服务器配置?
如何制作网站标识牌,动态网站如何制作(教程)?
建站之星代理平台如何选择最佳方案?
如何快速生成橙子建站落地页链接?
单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?
建站之星伪静态规则如何正确配置?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
大型企业网站制作流程,做网站需要注册公司吗?
名字制作网站免费,所有小说网站的名字?
在线流程图制作网站手机版,谁能推荐几个好的CG原画资源网站么?
,网站推广常用方法?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化
无锡营销型网站制作公司,无锡网选车牌流程?
完全自定义免费建站平台:主题模板在线生成一站式服务
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
怀化网站制作公司,怀化新生儿上户网上办理流程?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
开封网站制作公司,网络用语开封是什么意思?
建站之星图片链接生成指南:自助建站与智能设计教程
如何用5美元大硬盘VPS安全高效搭建个人网站?
头像制作网站在线制作软件,dw网页背景图像怎么设置?
如何用西部建站助手快速创建专业网站?
音乐网站服务器如何优化API响应速度?
建站主机与虚拟主机有何区别?如何选择最优方案?
如何在阿里云完成域名注册与建站?
网站制作说明怎么写,简述网页设计的流程并说明原因?
,南京靠谱的征婚网站?
建站之星2.7模板:企业网站建设与h5定制设计专题
贸易公司网站制作流程,出口贸易网站设计怎么做?
制作网站的基本流程,设计网站的软件是什么?
临沂网站制作公司有哪些,临沂第四中学官网?
建站之星CMS五站合一模板配置与SEO优化指南
建站之星下载版如何获取与安装?
建站主机是否属于云主机类型?
如何获取免费开源的自助建站系统源码?
建站之星安装路径如何正确选择及配置?
,怎么在广州志愿者网站注册?
建站之星如何助力网站排名飙升?揭秘高效技巧
哈尔滨网站建设策划,哈尔滨电工证查询网站?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
如何配置IIS站点权限与局域网访问?
建站主机选购指南:核心配置优化与品牌推荐方案
如何在橙子建站上传落地页?操作指南详解
PHP 500报错的快速解决方法
*请认真填写需求信息,我们会在24小时内与您取得联系。