引用类型分为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类似。只不过从数组右侧开始。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]