JS 数组常用方法

一、JavaScript中创建数组的方式

1.创建空数组,再给数组元素赋值

//创建数组,不定义元素个数
var myCars= new Array();

//给数组元素赋值  可以不按照数组顺序进行赋值
myCars[0]="aodi";
myCars[1]="baoma";
myCars[2]="benchi";

console.log(myCars);//[aodi,baoma,benchi]

2.使用new Array()创建数组

var citys = new Array("杭州", "绍兴", "宁波", "温州");
console.log(citys);//[杭州,绍兴,宁波,温州]

3.使用数组字面量(隐式)

var citys = ["杭州", "绍兴", "宁波", "温州"];
console.log(citys);//[杭州,绍兴,宁波,温州]

4.Array.of创建数组(ES6新增)

Array.of()方法用于将一组值,转换为数组。

Array.of()总是返回参数值组成的数组。如果没有参数,就返回一个空数组。

Array.of(3, 11, 8) // [3,11,8]
Array.of(3) // [3]
Array.of(3).length // 1

5.Array.from创建数组(ES6新增)

Array.from()方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map)。

let arrayLike = {   //类似数组的对象
    0: 'tom', 
    1: '65',
    2: '男',
    3: ['jane','john','Mary'],
    'length': 4
}
//转化为真正的数组
let arr = Array.from(arrayLike)
console.log(arr) // ['tom','65','男',['jane','john','Mary']]

Array.from的三个参数:

Array.from(arrayLike[, mapFn[, thisArg]] )
1 参数一是被转换的对象
2 参数二是一个map函数方法
3 参数三是map里面this的指向

注意:数组中如果不添加元素,那打印出来的元素的值默认就是undefined

二、数组常用方法汇总

JS数组方法 作用 返回值 用法
join 把数组转换成字符串,可以设置连接符 字符串 arr.join("-")
push 数组末尾增加内容 新数组的长度 arr.push(" ")
pop 删除数组最后一项 删除的值 arr.pop( )
shift 删除数组第一项 删除的值 arr.shift(" ")
unshift 数组开头增加内容 新数组的长度 arr.unshift(" ")
sort 数组里的项从小到大排序(比较字符串) 新数组 arr.sort( )
reverse 反转数组项的顺序 新数组 arr.reverse( )
concat() 数组拼接,不改变原来数组 新数组 arr.concat()
slice() 数组截取 新数组 arr.slice( 开始下标 , 结束下标)
splice() 删除、插入和替换 新数组 arr.splice( 2,0,4,6 )
indexOf() 从前往后查找 返回索引(最新) arr.indexof( 5 )
lastIndexOf() 从后往前查找 返回索引(最新) arr.lastIndexOf(5)
forEach() 对数组进行遍历循环 arr.forEach()
map() “映射”数组,对数组元素进行函数调用 新数组 arr.map()
filter() “过滤”数组,返回满足条件的元素 新数组 arr.filter()
every() 数组中每个元素是否都满足条件,逻辑“与” true或false arr.every()
some() 数组中是否存在满足条件的元素,逻辑“或” true或false arr.some()
prototype 查找数组的原型 proty Array.prototype
ES6新增的方法
find() 查找符合条件的元素 元素orubdefined arr.find()
findIndex() 查找符合条件的元素的索引 对应的索引 arr.findIndex()
includes() 判断一个数组是否包含一个指定的值 true或false arr.includes(value)
Array.isArray() 判断一个对象是否为数组 true或false Array.isArray([])
fill() 使用给定值,填充一个数组 新数组 Array(conut).fill(value)

三、js数组常用的方法

1. join()

  • join,就是把数组转换成字符串,然后给他规定个连接字符,默认的是逗号( ,)
  • 书写格式:join(" "),括号里面写字符串 (“要加引号”),
var arr = [1,2,3];
console.log(arr.join());  // 1,2,3
console.log(arr.join("-")); // 1-2-3
console.log(arr);   
// [1, 2, 3(原数组不变)

2. push()和pop()

  • push(): 把里面的内容添加到数组末尾,并返回修改后的长度。
  • pop():移除数组最后一项,返回移除的那个值,减少数组的length。
  • 书写格式:arr.push(" "),括号里面写内容 (“字符串要加引号”),
  • 书写格式:arr.pop( )
var arr = ["Lily","lucy","Tom"];
var count = arr.push("Jack","Sean");
console.log(count);   // 5
console.log(arr);   
// ["Lily", "lucy", "Tom", "Jack", "Sean"]
var item = arr.pop();
console.log(item);   // Sean
console.log(arr);   
// ["Lily", "lucy", "Tom", "Jack"]

3. shift() 和 unshift()

  • shift():删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined 。
  • unshift:将参数添加到原数组开头,并返回数组的长度 。
  • 书写格式:arr.shift(" "),括号里面写内容 (“字符串要加引号”),
var arr = ["Lily","lucy","Tom"];
var count = arr.unshift("Jack","Sean");
console.log(count);               // 5
console.log(arr);                //["Jack", "Sean", "Lily", "lucy", "Tom"]
var item = arr.shift();
console.log(item);   // Jack
console.log(arr);   
// ["Sean", "Lily","lucy", "Tom"]

4. sort()

  • sort():将数组里的项从小到大排序(字符串类型)
  • 书写格式:arr.sort( )
var arr1 = ["a", "d", "c", "b"];
console.log(arr1.sort());  
// ["a", "b", "c", "d"]

5. reverse()

  • reverse():反转数组项的顺序。
  • 书写格式:arr.reverse( )
 var arr = [13, 24, 51, 3];
console.log(arr.reverse());        
 //[3, 51, 24, 13]
console.log(arr);              
 //[3, 51, 24, 13](原数组改变)

6. concat()

  • concat() :将参数添加到原数组中。这个方法会先创建当前数组一个副本,然后将接收到的参数添加到这个副本的末尾,最后返回新构建的数组。在没有给 concat()方法传递参数的情况下,它只是复制当前数组并返回副本。
  • 书写格式:arr.concat(),括号里面写内容 (“字符串要加引号”),
//场景1:数组和元素的拼接
var arr = [1,3,5,7];
var arrCopy = arr.concat(9,[11,13]);
console.log(arrCopy);             
//[1, 3, 5, 7, 9, 11, 13]
console.log(arr);               
// [1, 3, 5, 7](原数组未被修改)


//场景2:两个数组的拼接
let arr = [1, 2, 3, 4, 5];
let arr1 = [6, 7, 8, 9];
let arr2 = arr.concat(arr1);
console.log(arr2);
//[1, 2, 3, 4, 5, 6, 7, 8, 9]

7. slice()

  • slice():返回从原数组中指定开始下标到结束下标之间的项组成的新数组。slice()方法可以接受一或两个参数,即要返回项的起始和结束位置。在只有一个参数的情况下, slice()方法返回从该参数指定位置开始到当前数组末尾的所有项。如果有两个参数,该方法返回起始和结束位置之间的项——但不包括结束位置的项。
  • 书写格式:arr.slice( 1 , 3)
var arr = [1,3,5,7,9,11];
var arrCopy = arr.slice(1);
var arrCopy2 = arr.slice(1,4);
var arrCopy3 = arr.slice(1,-2);
var arrCopy4 = arr.slice(-4,-1);
console.log(arr);               
//[1, 3, 5, 7, 9, 11](原数组没变)
console.log(arrCopy);             
//[3, 5, 7, 9, 11]
console.log(arrCopy2);            
//[3, 5, 7]
console.log(arrCopy3);            
//[3, 5, 7]
console.log(arrCopy4);            
//[5, 7, 9]

8.splice()

  • splice():删除、插入和替换。
  • 删除:指定 2 个参数:要删除的第一项的位置和要删除的项数。
  • 书写格式:arr.splice( 1 , 3 )
  • 插入:可以向指定位置插入任意数量的项,只需提供 3 个参数:起始位置、 0(要删除的项数)和要插入的项。
  • 书写格式:arr.splice( 2,0,4,6 )
  • 替换:可以向指定位置插入任意数量的项,且同时删除任意数量的项,只需指定 3 个参数:起始位置、要删除的项数和要插入的任意数量的项。插入的项数不必与删除的项数相等。
  • 书写格式:arr.splice( 2,0,4,6 )
var arr = [1,3,5,7,9,11];
var arrRemoved = arr.splice(0,2);
console.log(arr);                
//[5, 7, 9, 11]
console.log(arrRemoved);            
//[1, 3]
var arrRemoved2 = arr.splice(2,0,4,6);
console.log(arr);                
// [5, 7, 4, 6, 9, 11]
console.log(arrRemoved2);           // []
var arrRemoved3 = arr.splice(1,1,2,4);
console.log(arr);                
// [5, 2, 4, 4, 6, 9, 11]
console.log(arrRemoved3);           
//[7]

9.indexOf()和lastIndexOf()

  • indexOf():接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的开头(位置 0)开始向后查找。
  • 书写格式:arr.indexof( 5 )
  • lastIndexOf:接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。其中, 从数组的末尾开始向前查找。
  • 书写格式:arr.lastIndexOf( 5,4 )
var arr = [1,3,5,7,7,5,3,1];
console.log(arr.indexOf(5));       
//2
console.log(arr.lastIndexOf(5));    
//5
console.log(arr.indexOf(5,2));      
//2
console.log(arr.lastIndexOf(5,4));   
//2
console.log(arr.indexOf("5"));      
//-1

10. forEach()

  • forEach():对数组进行遍历循环,对数组中的每一项运行给定函数。这个方法没有返回值。参数都是function类型,默认有传参,参数分别为:遍历的数组内容;第对应的数组索引,数组本身。
  • 书写格式:arr.forEach()
var arr = [1, 2, 3, 4, 5];
arr.forEach(function(x, index, a){
console.log(x + '|' + index + '|' + (a === arr));
});
// 输出为:
// 1|0|true
// 2|1|true
// 3|2|true
// 4|3|true
// 5|4|true

11. map()

  • map():指“映射”,对数组中的每一项运行给定函数,返回每次函数调用的结果组成的数组。
  • 书写格式:arr.map()
var arr = [1, 2, 3, 4, 5];
var arr2 = arr.map(function(item){
return item*item;
});
console.log(arr2);        
//[1, 4, 9, 16, 25]

12.filter()

  • filter():“过滤”功能,数组中的每一项运行给定函数,返回满足过滤条件组成的数组。简单来说就是filter 返回一个新数组,数组中是满足条件的元素
  • 书写格式:arr.filter()
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
var arr2 = arr.filter(function(x, index) {
return index % 3 === 0 || x >= 8;
}); 
console.log(arr2);         
//[1, 4, 7, 8, 9, 10]

13. every()

  • every():判断数组中每一项都是否满足条件,只有所有项都满足条件,才会返回true。
  • 书写格式:arr.every()
var arr = [1, 2, 3, 4, 5];
var arr2 = arr.every(function(x) {
return x < 10;
}); 
console.log(arr2);         //true
var arr3 = arr.every(function(x) {
return x < 3;
}); 
console.log(arr3);         // false

14. some()

  • some():判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
  • 书写格式:arr.some()
var arr = [1, 2, 3, 4, 5];
var arr2 = arr.some(function(x) {
return x < 3;
}); 
console.log(arr2);         //true
var arr3 = arr.some(function(x) {
return x < 1;
}); 
console.log(arr3);         // false

15、查找数组的原型

console.log(Array.prototype);

查找数组的原型

四、ES6新增的数组方法

16、find()

  • find 在数组中查找符合条件的元素,找到就返回 并且终止循环 找不到就是ubdefined
  • 书写格式:arr.find()
    let arr = [{id:1,name:'dee'},{id:2,name:'dee'},{id:3,name:'dee'},
    {id:4,name:'dee'},{id:5,name:'dee'}];
    // let obj = arr.find(function(item){
    //    return item == 3;
    // })
    // console.log(obj);
    // ubdefined
    let obj = arr.find(item => item.id > 1)
    console.log(obj);
    ({id:2,name:'dee'})  

17、findIndex()

  • findIndex 在数组中查找符合条件的元素,找到就返回对应的索引 并且终止循环 -1
  • 书写格式:arr.findIndex()
    let arr = [1, 2, 3, 4, 5];
    let obj = arr.findIndex(function(item) {
        return item > 6;
    })
    console.log(obj);  // -1

18、includes()

  • includes()方法,判断一个数组是否包含一个指定的值,返回一个布尔值。 参数是一个value,一般用于简单数组。
  • 对于复杂数组,则可以使用some()方法替代includes()方法
  • 书写格式:arr.includes(value)
var a = [1,2,3]
console.log(a.includes(1))  // true

19、Array.isArray()方法

  • 用来判断一个对象是否为数组
Array.isArray([])  // true
Array.isArray({})  // false

20、fill()方法

  • fill方法使用给定值,填充一个数组。
['a', 'b', 'c'].fill(7)
// [7, 7, 7]

new Array(3).fill(7)
// [7, 7, 7]

上面代码表明,fill方法用于空数组的初始化非常方便。数组中已有的元素,会被全部抹去。

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

推荐阅读更多精彩内容