JS数组-汇总

一、JS数组概览(汇总)

1、find、findIndex

find:返回符合条件的第一个元素
findIndex: 返回符合条件的第一个元素的位置(下标)

let arr = [1,2,3,4,5];
let index = arr.findIndex(item=>{
  return item % 2 === 0
}) 
// index ========= 1

2、 splice

splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。会改变原数组
语法:array.splice(index,howmany,item1,.....,itemX)

实例:删除数组中的元素

var arr = [1,2,2,3,4,5,6];
var len = arr.length;
// 方法一(常规操作)
for(var i=0;i<len;i++){ 
  if(arr[i]==2){ // 删除所有为2的元素
    arr.splice(i,1);
    i--;
  }
}

// 方法二(从后往前遍历,代码更简单)
for(var i=len;i>=0;i--){
  if(arr[i]==2){
    arr.splice(i,1);
  }
}

// 方法三 (while)
while(i--){
  if(arr[i]==2){
    arr.splice(i,1);
  }
}

实例:指定位置添加元素

var arr= ["1", "2", "3", "4"];
arr.splice(2, 0, "111", "222"); // ["1","2","111","222","3","4"]

3、slice

slice(start,end)提取字符串的某个部分,并以新的字符串返回被提取的部分
不会改变原数组

/**
 * [1,2,3,4,5,6,7,8,9,10] => [[1,2,3],[4,5,6],[7,8,9],[10]]
 * size:3
 */
let arr = Array.from(new Array(10), (x, index) => {
  return index + 1
})
function getResultGroup(result,size) { 
  let arr1 = [];
  let len = result.length;
  for(let i = 0; i< len; i = i + size) {
    let arr2 = result;
    arr1.push(arr2.slice(i,i + size))
  }
  return arr1;
}

4、concat

concat() 方法用于连接两个或多个数组
返回一个新的数组,不会改变原数组

let arr1 = new Array(1,2,3);
let num = 4;
let arr2 = [5,6];
console.log(arr1.concat(num,arr2)) // [1,2,3,4,5,6]

5、indexOf

语法:Array.indexOf(a)
从数组头部开始查找某项,返回索引值(找到的第一个索引值),找不到返回-1

  • 案例-数组去重
// filter 遍历数组返回执行结果为true的项,组成一个新数组
let arr = [1,2,3,4,5,4,3,2,1];
let newArr = arr.filter((item,index)=>{
  return arr.indexOf(item) === index
})
console.log(newArr) // 返回 [1,2,3,4,5]

6、map

语法:array.map(function(currentValue,index,arr), thisValue)
参数:接收两个参数,一个是回调函数,另一个是回调函数的this值(可选)。回调函数接收三个参数,分别是当前值,当前索引和整个数组。
返回:函数返回一个新创建的数组,数组中的每个元素都经过了回调函数的处理,结果不改变原数组

let nums = [1, 2, 3];
let obj = {val: 5};
let newNums = nums.map(function(item,index,array) {
  return item + index + array[index] + this.val; 
  //对第一个元素,1 + 0 + 1 + 5 = 7
  //对第二个元素,2 + 1 + 2 + 5 = 10
  //对第三个元素,3 + 2 + 3 + 5 = 13
}, obj);
console.log(newNums);//[7, 10, 13]

7、filter

语法:array.filter(function(currentValue,index,arr), thisValue)
参数:接收一个函数参数。函数接收一个默认参数,就是数组正在遍历的当前元素,函数参数的返回值是一个布尔值,若返回true,则数组元素得到保留。
返回:返回该函数会返回true的项组成的数组,此函数不会改变原数组

let data = [ { id: 1, check: true }, {id: 2, check: false} { id: 4, check: true } ]
let newData = data.filter(item=>{
  return item.check;
});
console.log(newData); // 返回true的项组成的数组 

8、every和some

some:判断数组中是否存在满足条件的项,只要有一项满足条件,就会返回true。
every:判断数组中每一项是否都满足条件,只有所有项都满足条件,才会返回true

// every
let data = [{id: 1, check: true},{id: 2, check: false},
    {id: 3, check: false},{id: 4, check: true}];
    
let selectAll = data.every(item=>{
   return item.check;
});
console.log("every函数:"+selectAll) // data中每一项都为true才会返回true

// some
let hasCheck = data.some(item=>{
    return item.check;
});
console.log("some函数:"+hasCheck); // data中任一一项返回true则会返回true

9、reduce

语法:reduce(callback,initiaValue)会传入两个变量,回调函数(callback)和初始值(initiaValue)。
reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。对空数组是不会执行回调函数的。

案例:

  • 计算数组总和
var num = [1,2,3,4,5];
var res = num.reduce(function(total,num){
    return total+num;
},0);
console.log(res);//15
  • 合并二维数组
var red = [[0, 1], [2, 3], [4, 5]].reduce(function(a, b) {
 return a.concat(b);
}, []);
console.log(red) // [0, 1, 2, 3, 4, 5]
  • 统计一个数组中有多少个不重复的单词
// 不用reduce时:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
  var obj = {};
  for(var i= 0, l = arr.length; i< l; i++){
    var item = arr[i];
    obj[item] = (obj[item] +1 ) || 1;
  }
  return obj;
}
console.log(getWordCnt()); // {apple: 2, orange: 3, pear: 1}

// 用reduce时:
var arr = ["apple","orange","apple","orange","pear","orange"];
function getWordCnt(){
  return = arr.reduce(function(prev,next) {
    prev[next] = (prev[next] + 1) || 1;
    return prev;
  },{})
}
console.log(getWordCnt()); // {apple: 2, orange: 3, pear: 1}

10、Array.from()

  • 将具有length属性的对象 转成数组
let arrayLike = {
  '0': 'a',
  '1': 'b',
  '2': 'c',
  length: 3
};
// ES5
let arr = Array.prototype.slice.call(arrayLike);
// ES6
let arr1 = Array.from(arrayLike);
console.log(arr); //['a','b','c'];
console.log(arr1); //['a','b','c'];

补充:关于slice大致内部实现

Array.prototype.slice = function(start,end){
     var result = new Array();
     start = start || 0;
     //this指向调用的对象,当用了call后,能够改变this的指向,也就是指向传进来的对象
     end = end || this.length; 
     for(var i = start; i < end; i++){
          result.push(this[i]);
     }
     return result;
}
  • Array.from()方法的第二个参数

Array.from()方法的第二个参数类似与数组的map方法,用于对每个元素进行处理,并将处理后的结果放入返回的数组。

let arrayLike = {
    '0': 1,
    '1': 2,
    '2': 3,
    length: 3
};
// ES6
let arr1 = Array.from(arrayLike, ele => ele + 1); //[2,3,4]
// ES5
let arr2 = Array.prototype.map.call(arrayLike, ele => ele + 1); //[2,3,4]
// 等同于
let arr3 = Array.from(arrayLike).map(ele => ele + 1); //[2,3,4];
  • 举例:快速生成包含10个数字1的数组
let arrayLike = {length: 10};
let arr = Array.from(arrayLike, () => 1);
  • 举例:生成数字范围
function range(end) {
 return Array.from({ length: end }, (_, index) => index)
}
console.log(range(4)); // => [0, 1, 2, 3]

拓展

数组的拷贝
arrayObj.slice(0); //返回数组的拷贝数组,注意是一个新的数组,不是指向
arrayObj.concat(); //返回数组的拷贝数组,注意是一个新的数组,不是指向

数组元素的字符串化
arrayObj.join(separator); //返回字符串
let arr = [1,2,3,4,5,6];
console.log(arr.join(',')) // 1,2,3,4,5,6

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

推荐阅读更多精彩内容