数组常用方法总结

前言

最近工作的时候总是记不住数组,对象,字符串的方法,写一篇方法总结好好的巩固一下,以后也好复习。

数组的定义

数组的标准定义是:一个存储元素的线性集合,元素可以通过索引任意存取,索引通常是数字,用来计算元素间存储位置的偏移量。

创建数组的方法

  1. 直接量创建(最常用)
  let arr = [1,2,3] 
  1. 利用构造函数创建
  • 不传参的时候会创建一个空数组
  var arr = new Array()//创建一个空数组
  • 传一个参数,用来指定这个数组的长度
var arr = Array(5);//创建一个数组长度为5的数组
console.log(arr);//会打印出长度为10的数组,数组元素为empty
  • 传一组元素,作为数组的初始值
var arr = new Array(1,2,3,4,5)//创建一个[1,2,3,4,5]的数组

感觉写代码的时候还是第一种用的最多,也没有研究过两种方式的差异,等有时间研究一下。

push()和pop()

  • push()方法

可以接收任意数量的参数,并逐个添加到数组末尾,并返回修改后数组的长度。

let arr = [1,2,3[];
console.log(arr.push(4,5,6));//返回6
console.log(arr)//返回[1,2,3,4,5,6]
  • pop()方法

pop方法是移除数组的最后一项,并返回移除的值

let arr = [1,2,3];
console.log(arr.pop());//返回3
console.log(arr)//返回1,2

shift()和unshift()

  • shift()方法

shift()方法是删除数组第一项,返回删除的值;和pop()删除的位置相反;

let arr  = [1,2,3];
console.log(arr.shift());//返回1
console.log(arr);//返回[2,3]
  • unshift()方法

unshift()方法是将参数添加到数组开发,并返回数组长度。和push()方法刚好相反。

let arr = [2,3];
console.log(arr.unshift(1));//返回3
console.log(arr)//返回[1,2,3]

join()方法

join()方法,接受一个参数,分隔符,不传默认是“,”,会将数组变为字符串,但本身的数组不会发生变化。感觉各个类型之间的转化也需要总结一下,之后有时间总结吧。

let arr = [1,2,3]
console.log(arr.join())//返回"1,2,3"
console.log(arr.join("-")//返回"1-2-3"
console.log(arr)//返回[1,2,3]

sort()方法

sort()方法是将数组按照升序排序,返回排序后数组,说得更精确点,是按照字符编码的顺序进行排序。并可接收一个比较函数做参数来改变排序。比较函数可接收两个参数。
!!请注意,数组在原数组上进行排序,不生成副本。

let arr = [7,4,6,9,5,1]
console.log(arr.sort());//返回[1, 4, 5, 6, 7, 9]
console.log(arr)//返回[1, 4, 5, 6, 7, 9],原数组发生了改变

reverse()方法

reverse() 方法用于颠倒数组中元素的顺序。

let arr = [1,2,3];
console.log(arr.reverse());//返回[3,2,1]

concat()方法

concat() 方法用于连接两个或多个数组。该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。

let arr = [1,2,3];
let arr2 = [4,5,6];
let arr3 = arr.concat(arr2);
console.log(arr.arr2.arr3);//返回 [1, 2, 3, 4, 5, 6]

slice()方法

slice() 方法可从已有的数组中截取选定的元素返回组成新的数组,原数组不变。
方法接收两个参数,起始位置和结束位置。起始位置必需,默认是0,结束位置可选。
!!注意:起始位置是从0开始的,光写slice()就是默认起始位置为0,如果起始位置为负数,则会从数组末尾开始截取。当起始位置为负数时,结束位置如果是正数或者比起始位置小就会返回空数组。结束位置需要大于起始位置,截取的新数组元素不会包含结束位置的元素。

let arr = [1,2,3,4,5];
console.log(arr.slice(1))//返回[2,3,4,5]
console.log(arr.slice(1,3))//返回[2,3]
console.log(arr.slice(-3))//返回[3, 4, 5]
console.log(arr.slice(-3,-5))//返回[]
console.log(arr.slice(-3,-1))//返回[3,4]

splice()方法

splice() 方法向/从数组中添加/删除/插入/替换项目,然后返回被删除的项目。

注意:该方法会改变原始数组。

  • 删除 : 需要两个参数,起始位置和结束位置,返回删除的元素组成的新数组。可以删除任意个数组元素。
  • 插入:需要三个参数,起始位置,0(要删除的个数),插入的元素
  • 替换:需要三个参数,起始位置,删除个数,要插入的项,填入的元素不必与删除的个数相等。
注意:splice()方法始终返回一个数组,,该数组中包含从原始数组中删除的项,如果没有删除任何项,则返回一个空数组。
let arr = [1,2,3,4,5]
//删除元素
console.log(arr.splice(1,2))//返回[1,2]
console.log(arr)//返回[3,4,5],原数组发生了改变
//插入元素
arr.splice(3,0,6,7)//意思是在数组的位置3后插入6,7
console.log(arr)//返回[3,4,5,6,7]
//替换元素
arr.splice(1,2,8,9,10)//意思是在元素位置1后删除2个元素,并插入8,9,10,返回[4,5]
console.log(arr)//返回[3, 8, 9, 10, 6, 7]

ES5新增的方法

##### 下面是ES5新增的数组方法

indexOf()和 lastIndexOf()方法

  • indexOf()方法是查找数组中有无匹配的值,传两个参数,要查找的项和起始位置,如果严格匹配后找到则返回元素的位置下标,如没有则返回-1
let arr = [1,2,3,4,5];
console.log(arr.indexOf(3,0));//返回2,即位置下标
console.log(arr.indexOf(6,0))//返回-1
  • lastIndexOf()方法就是从后往前找,就不举例说明了。

forEach()

forEach()方法是对数组进行遍历,参数是function,function中传的是元素,元素下标,数组本身。

let arr = [1,2,3,4,5];
arr.forEach(function(item,index,arr){
  console.log(item+'|'+index+'|'+arr)
})

map()

map()方法及映射,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。就是对数组每项元素进行操作后返回新的数组。
注意: map() 不会对空数组进行检测。map() 不会改变原始数组。map() 方法按照原始数组元素顺序依次处理元素。

 let arr = [];
let arr2 = arr.map(function(item){
  return item*item;
})

filter()

filter方法就是过滤数组元素,将满足条件的数组元素返回并组成新的数组。

  let arr = [1,2,3]
  let arr2 = arr.filter(function(item){
    return item%2 == 0;
  })
console.log(arr2)//[2]

every()方法和some()方法

两个方法都是判断数组元素是否满足条件,并返回true和false;

  • every()方法是数组每一项都需要满足条件才返回true,否则返回false;
  • some则是只要有满足条件的元素,就会返回true;

ES6新增的方法

等待更新。。。

参考资料

https://www.cnblogs.com/obel/p/7016414.html
W3C JavaScript Array 对象

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

推荐阅读更多精彩内容