JavaScript中的数组方法

一、在使用数组之前需要先定义数组,定义数组的方式有以下两种:

var arr1=[];
var arr2=[5,2,3,4];//字面量方式创建数组

var arr3=new Array();
var arr4=new Array(5,2,3,4);//构造函数创建数组

构造函数创建数组和字面量创建数组的区别:

var arr1=[5];//创建了一个里面只有一个元素为5的数组
var arr2=new Array(5);//创建了一个长度为5的空数组,里面存放的undefined,
//构造函数的参数如果为负数或者小数会报错

注: 任何两个数组都不相等

二、数组的分类

根据数组中存放的值的类型不同,我们可以强行分为数值型数组,字符型数组,对象型数组(json)等等

三、数组的访问

  • 通过arr.length可以获取数组的长度
  • 通过arr[i]可以访问数组中的元素

四、数组的方法

1. arr.push(元素)

  • 参数:要增加的元素
  • 功能:在数组的末尾追加元素
  • 返回值:返回增加以后数组的长度
  • 是否修改原数组:是
var arr=[1,2,3];
var res=arr.push("hello");//返回值是4
conosle.log(arr);//[1,2,3,"hello"];

2. arr.unshift(元素)

  • 参数:要增加的元素
  • 功能:在数组的头部追加元素
  • 返回值:返回增加以后数组的长度
  • 是否修改原数组:是
var arr=[1,2,3];
var res=arr.unshift("hello");//返回值是4
conosle.log(arr);//["hello",1,2,3];

3. arr.pop()

  • 参数:没有参数
  • 功能:删除数组中的最后一位数据
  • 返回值:返回被删除的值
  • 是否修改原数组:是
var arr=[1,2,3];
var res=arr.pop();//返回值是3
conosle.log(arr);//[1,2];

4. arr.shift()

  • 参数:没有参数
  • 功能:删除数组中的第一位数据
  • 返回值:返回被删除的值
  • 是否修改原数组:是
var arr=[1,2,3];
var res=arr.shift();//返回值是1
conosle.log(arr);//[2,3];

5. arr.splice(参数1,参数2,参数3...)

  • 参数:
    • 一个参数:从指定索引,删除数据到结束
    • 两个参数:从指定索引,删除指定长度的数据
    • 多个参数:从指定索引,删除指定长度的数据,填充第三个参数向后的所有数据
  • 功能:根据参数不同,功能不同
  • 返回值:被删除的数据组成的数组
  • 是否修改原数组:是
var arr=[1,2,3,4,5];
var res1=arr.splice(1);//返回值是[2,3,4,5]
var res2=arr.splice(1,2);//返回值是[2,3]
var res3=arr.splice(1,2,"hello",3);//返回值是[2,3],数组执行后变成[1,4,5,"hello",3]

6. arr.reverse()

  • 参数:没有参数
  • 功能:逆置数组
  • 返回值:逆置后的数组
  • 是否修改原数组:是
var arr=[1,2,3];
var res=arr.reverse();//返回值是[3,2,1]
conosle.log(arr);//[3,2,1]

7. arr.join(str)

  • 参数:若没有参数,转换为逗号连接的字符串,如有参数,转为以固定参数连接的字符串
  • 功能:将数组转为字符串
  • 返回值:转换以后的字符串
  • 是否修改原数组:否
var arr=[1,2,3];
var res=arr.join();//返回值是1,2,3
var res2=arr.join("|")//返回值是1|2|3

8. arr.slice(参数1,参数2)

  • 参数:
    • 一个参数:从指定位置开始截取数组
    • 两个参数:从指定索引开始截取,截取到指定索引(第二个参数)的前一个,左闭右开
  • 功能:截取指定范围内的数组
  • 返回值:截取到的数组
  • 是否修改原数组:否
var arr=[1,2,3,4];
var res=arr.slice(1);//返回值是[2,3,4]
var res2=arr.slice(1,3)//返回值是[2,3]

9. arr.sort(function(a,b){})

  • 参数:回调函数
arr.sort(function(a,b){
  return a-b;//升序排列
})
arr.sort(function(a,b){
  return b-a;//降序排列
})
  • 功能:排序数组
  • 返回值: 排序后的数组
  • 是否修改原数组:是
var arr=[1,4,3,2];
var res=arr.sort(function(a,b){
  return a-b;
});//返回值是[1,2,3,4]
var res2=arr.sort(function(a,b){
  return b-a;
});//返回值是[4,3,2,1]

10. arr.concat(元素或数组)

  • 参数:元素或数组
  • 功能:拼接数组
  • 返回值:拼接后的数组
  • 是否修改原数组:否
    注意:拼接数组的时候只拆分最外层数组进行拼接
var arr=[1,2,3];
var res=arr.concat(9,0,[4,5,[7,9]]);//返回值是[1,2,3,9,0,4,5,[7,9]]
conosle.log(arr);//[1,2,3]

以下是ES5新增方法

11. arr.indexOf(元素,start)

  • 参数:
    • 一个参数:查询数组中是否含有某个数据
    • 两个参数:从指定的索引开始查找数组中是否含有某个数据
  • 功能: 查询指定数据的下标并且返回
  • 返回值:如果数据中含有该数据,返回该数据的索引,没有找到返回-1
  • 是否修改原数组: 否
var arr=[1,2,3,4,5,2];
var res=arr.indexOf(2,2);//返回值是5
var res1=arr.indexOf(6);//返回-1

12. arr.lastIndexOf(元素,start)

  • 参数:
    • 一个参数:查询数组中是否含有某个数据
    • 两个参数:从指定的索引开始查找数组中是否含有某个数据
  • 功能:从后向前查询指定数据的下标并且返回
  • 返回值:如果数据中含有该数据,返回该数据的索引,没有找到返回-1
  • 是否修改原数组: 否
var arr=[1,2,3,4,5,2];
var res=arr.lastIndexOf(2);//返回值是5
var res1=arr.lastIndexOf(6);//返回-1

13. arr.forEach(function(val,index,arr){})

  • 参数: 回调函数
  • 功能:遍历数组
  • 返回值:undefined
  • 是否修改原数组: 否
    回调函数的返回值:无
var arr=[1,2,3,4,5,2];
arr.forEach(function(value,index,arr){
  console.log(value+"-"+index+"-"+"arr");
//value代表数组中的值,index代表数组索引,arr代表数组本身
})

14. arr.map(function(val,index,arr){})

  • 参数: 回调函数
  • 功能:遍历数组
  • 返回值:数组
    • 如果回调函数中没有返回值,返回一个和原数组长度相同的数组,值均为undefined 注:此处不是空数组
    • 如果回调函数中有返回值,则返回回调函数中的数据组成的数组
  • 是否修改原数组: 否
    回调函数的返回值造成了什么影响:回调函数的返回值被放在了map最终返回的数组内
var arr=[1,2,3,4,5,2];
arr.map(function(value,index,arr){
  return value*3;//将数组中所有元素增加百分之三十并返回
})

15. arr.filter(function(val,index,arr){})

  • 参数: 回调函数
  • 功能:遍历数组,过滤符合条件的值
  • 返回值:数组
    • 如果回调函数中没有返回值,返回一个空数组 注:此处是空数组
    • 如果回调函数中有返回值,若回调函数的return语句为true,将本次数据返回给filter,最后filter将所有回调函数的返回值组成新数组返回,若return语句为false,返回空数组 默认为false
  • 是否修改原数组: 否
    回调函数的返回值:回调函数的返回值若为true,则返回给filter,若为false,返回空
var arr=[1,2,3,4,5,2];
var res=arr.filter(function(value,index,arr){
  return value>3;//返回值为[4,5]
})

16. arr.some(function(val,index,arr){})

  • 参数: 回调函数
  • 功能:遍历数组
  • 返回值:布尔值
    • 回调函数没有返回值时,返回false
    • 回调函数有返回值,如果数组中含有符合条件的值,则返回true并立即停止遍历,否则返回false
  • 是否修改原数组: 否
    回调函数的返回值:默认为false
var arr=[1,2,3,4,5,2];
arr.some(function(value,index,arr){
  return value>3;//遍历到4时停止遍历,并返回true
})

17. arr.every(function(val,index,arr){})

  • 参数: 回调函数
  • 功能:遍历数组
  • 返回值:布尔值
    • 回调函数没有返回值时,返回false
    • 回调函数有返回值,如果数组中所有值均符合条件,则返回true,有一个不符合就停止遍历并返回false
  • 是否修改原数组: 否
    回调函数的返回值:默认为false
var arr=[5,2,3,4,1,2];
var res=arr.every(function(value,index,arr){
  return value>3;//遍历到2时停止遍历,并返回false
})

18. arr.reduce(function(prev,val,index,arr){},参数2)

  • 参数:第一个参数为回调函数,第二个参数如果存在,则存放在第一次遍历的prev中
  • 功能:遍历数组,迭代
  • 返回值:
    • 回调函数没有返回值时,返回undefined
    • 回调函数有返回值,每次将返回值返回到prev中 注:prev是上一次回调函数的返回值,第一次为数组中的第一个数据
  • 是否修改原数组: 否
    回调函数的返回值:返回所有prev迭代后的值
var arr=[5,2,3,4,1,2];
var res=arr.reduce(function(prev,value,index,arr){
  return prev+value;//返回值为17(所有元素之和)
})
var res2=arr.reduce(function(prev,value,index,arr){
  return prev+value;//返回值为18,因为有参数2
},1)

19. arr.reduceRight(function(prev,val,index,arr){},参数2)

  • 参数:第一个参数为回调函数,第二个参数如果存在,则存放在第一次遍历的prev中
  • 功能:遍历数组,迭代
  • 返回值:
    • 回调函数没有返回值时,返回undefined
    • 回调函数有返回值,每次将返回值返回到prev中 注:prev是上一次回调函数的返回值,第一次为数组中的最后一个数据
  • 是否修改原数组: 否
    回调函数的返回值:返回所有prev迭代后的值
var arr=[5,2,3,4,1,2];
var res=arr.reduceRight(function(prev,value,index,arr){
  return prev+value;//返回值为17(所有元素之和)
})
var res2=arr.reduceRight(function(prev,value,index,arr){
  return prev+value;//返回值为18,因为有参数2
},1)

欢迎大家补充指正...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容