数组基本操作可以归纳为 增、删、改、查,需要留意的是哪些方法会对原数组产生影响,哪些方法不会

下面对数组常用的操作方法做一个归纳

下面前三种是对原数组产生影响的增添方法,第四种则不会对原数组产生影响

  1. push()
  2. unshift()
  3. splice()
  4. concat()

push()

push()方法接收任意数量的参数,并将它们添加到数组末尾,返回数组的最新长度

let colors = []; // 创建一个数组
let count = colors.push("red", "green"); // 推入两项
console.log(count) // 2

unshift()

unshift()在数组开头添加任意多个值,然后返回新的数组长度

let colors = new Array(); // 创建一个数组
let count = colors.unshift("red", "green"); // 从数组开头推入两项
alert(count); // 2

splice()

传入三个参数,分别是开始位置、0(要删除的元素数量)、插入的元素,返回空数组

let colors = ["red", "green", "blue"];
let removed = colors.splice(1, 0, "yellow", "orange")
console.log(colors) // red,yellow,orange,green,blue
console.log(removed) // []

concat()

首先会创建一个当前数组的副本,然后再把它的参数添加到副本末尾,最后返回这个新构建的数组,不会影响原始数组

let colors = ["red", "green", "blue"];
let colors2 = colors.concat("yellow", ["black", "brown"]);
console.log(colors); // ["red", "green","blue"]
console.log(colors2); // ["red", "green", "blue", "yellow", "black", "brown"]

下面三种都会影响原数组,最后一项不影响原数组:

  1. pop()
  2. shift()
  3. splice()
  4. slice()

pop()

pop() 方法用于删除数组的最后一项,同时减少数组的length 值,返回被删除的项

let colors = ["red", "green"]
let item = colors.pop(); // 取得最后一项
console.log(item) // green
console.log(colors.length) // 1

shift()

shift()方法用于删除数组的第一项,同时减少数组的length 值,返回被删除的项

let colors = ["red", "green"]
let item = colors.shift(); // 取得第一项
console.log(item) // red
console.log(colors.length) // 1

slice()

slice() 用于创建一个包含原有数组中一个或多个元素的新数组,不会影响原始数组

let colors = ["red", "green", "blue", "yellow", "purple"];
let colors2 = colors.slice(1);
let colors3 = colors.slice(1, 4);
console.log(colors)   // red,green,blue,yellow,purple
concole.log(colors2); // green,blue,yellow,purple
concole.log(colors3); // green,blue,yellow

即修改原来数组的内容,常用splice

splice()

传入三个参数,分别是开始位置,要删除元素的数量,要插入的任意多个元素,返回删除元素的数组,对原数组产生影响

let colors = ["red", "green", "blue"];
let removed = colors.splice(1, 1, "red", "purple"); // 插入两个值,删除一个元素
console.log(colors); // red,red,purple,blue
console.log(removed); // green,只有一个元素的数组

即查找元素,返回元素坐标或者元素值

  1. indexOf()
  2. includes()
  3. find()

indexOf()

返回要查找的元素在数组中的位置,如果没找到则返回-1

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
numbers.indexOf(4) // 3

includes()

返回要查找的元素在数组中的位置,找到返回true,否则false

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
numbers.includes(4) // true

find()

返回第一个匹配的元素

const people = [{name: "Matt",age: 27},{name: "Nicholas",age: 29}
];
people.find((element, index, array) => element.age < 28) // // {name: "Matt", age: 27}

二、排序方法

数组有两个方法可以用来对元素重新排序:

  1. reverse()
  2. sort()

reverse()

顾名思义,将数组元素方向排列

let values = [1, 2, 3, 4, 5];
values.reverse();
alert(values); // 5,4,3,2,1

sort()

sort()方法接受一个比较函数,用于判断哪个值应该排在前面

function compare(value1, value2) {if (value1 < value2) {return -1;} else if (value1 > value2) {return 1;} else {return 0;}
}
let values = [0, 1, 5, 10, 15];
values.sort(compare);
alert(values); // 0,1,5,10,15

三、转换方法

常见的转换方法有:

join()

join() 方法接收一个参数,即字符串分隔符,返回包含所有项的字符串

let colors = ["red", "green", "blue"];
alert(colors.join(",")); // red,green,blue
alert(colors.join("||")); // red||green||blue

四、迭代方法

常用来迭代数组的方法(都不改变原数组)有如下:

  1. some()
  2. every()
  3. forEach()
  4. filter()
  5. map()

some()

对数组每一项都运行传入的函数,如果有一项函数返回 true ,则这个方法返回 true

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let someResult = numbers.some((item, index, array) => item > 2);
console.log(someResult) // true

every()

对数组每一项都运行传入的函数,如果对每一项函数都返回 true ,则这个方法返回 true

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let everyResult = numbers.every((item, index, array) => item > 2);
console.log(everyResult) // false

forEach()

对数组每一项都运行传入的函数,没有返回值

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
numbers.forEach((item, index, array) => {// 执行某些操作
});

filter()

对数组每一项都运行传入的函数,函数返回 true 的项会组成数组之后返回

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let filterResult = numbers.filter((item, index, array) => item > 2);
console.log(filterResult); // 3,4,5,4,3

map()

对数组每一项都运行传入的函数,返回由每次函数调用的结果构成的数组

let numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1];
let mapResult = numbers.map((item, index, array) => item * 2);
console.log(mapResult) // 2,4,6,8,10,8,6,4,2

五、 数组去重

数组去重,一般都是在面试的时候才会碰到,一般是要求手写数组去重方法的代码。
在真实的项目中碰到的数组去重,一般都是后台去处理,很少让前端处理数组去重。虽然日常项目用到的概率比较低,但还是需要了解一下,以防面试的时候可能回被问到。

1)es6 Set方法去重

//es6方法数组去重,方法1
let arr = [1,1,'true','true',true,true,15,15,false,false, undefined,undefined, null,null, NaN, NaN,'NaN', 0, 0, 'a', 'a',{},{}];
let s = [...new Set(arr)];
//[1, "true", true, 15, false, undefined, null, NaN, "NaN", 0, "a", {}, {}]  //{}空对象没有去除//es6方法数组去重,方法2
function dedupe(array) {return Array.from(new Set(array));  //直接new Set()出来是个对象,Array.from()能把set结构转换为数组
}

2)利用indexOf去重
新建一个空数组,for循环原数组,判断结果数组是否存在当前元素,有相同的值跳过,不相同则push进新数组

//利用indexOf去重fliterArray (array) {const tempArr = []for (var i = 0; i < array.length; i++) {if (tempArr.indexOf(array[i]) === -1) {tempArr.push(array[i])console.log(tempArr, 'tempArr')}}return tempArr},const array4 = [1, 1, 'true', 'true', true, true, 15, 15, false, false, undefined, undefined, null, null, NaN, NaN, 'NaN', 0, 0, 'a', 'a', {}, {}]this.fliterArray(array4)// [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}]  //NaN、{}没有去重

3)利用includes

fliterArray (array) {const tempArr = []for (var i = 0; i < array.length; i++) {if (!tempArr.includes(array[i])) {tempArr.push(array[i])console.log(tempArr, 'tempArr')}}return tempArr},const array4 = [1, 1, 'true', 'true', true, true, 15, 15, false, false, undefined, undefined, null, null, NaN, NaN, 'NaN', 0, 0, 'a', 'a', {}, {}]this.fliterArray(array4)// [1, "true", true, 15, false, undefined, null, NaN, NaN, "NaN", 0, "a", {…}, {…}]  //{}没有去重

后期看到一篇文章讲的也很棒很全面:
JS内置对象

JS内置对象就是指Javascript自带的一些对象,供开发者使用,这些对象提供了一些常用的的功能。

常见的内置对象有Math、String、Array、Date等

Javscript数组的常用方法有哪些?相关推荐

  1. 七、ref引用与数组的常用方法

    一.ref 引用 1.1.什么是 ref 引用 ref 用来辅助开发者在不依赖于jQuery的情况下,获取 DOM 元素或组件的引用. 每个vue的组件实例上,都包含一个$refs对象,里面存储着对应 ...

  2. JS中数组的常用方法(concat拼接,join修改间隔符,pop移除最后一个元素,push在数组最后添加新的元素,reverse反转数组元素,shift移除第一个元素,unshift添加,spli)

    <html><head><title>js数组的常用方法</title><meta charset="UTF-8"/>& ...

  3. JS基础-数组的常用方法(ES3)

    数组的常用方法 数组是一个复杂数据类型,我们在操作它的时候就不能再像基本数据类型一样操作了 比如我们想改变一个数组 // 创建一个数组 var arr = [1, 2, 3]​ // 我们想把数组变成 ...

  4. 渡一教育公开课web前端开发JavaScript精英课学习笔记(十)数组的常用方法

    数组的常用方法(ES3) 以ES3.0为基础,ES5.0 在ES3基础上扩展,ES6.0 在ES5基础上扩展. 改变原数组的方法: push.pop.shift.unshift.sort.revers ...

  5. Swift 数组及常用方法

    Swift 数组及常用方法 1. 创建数组 // 创建整型数组 var array1: [Int] = [] // [] var arrya2: Array<Int> = [1, 2, 3 ...

  6. java数组的声明_Java数组定义常用方法

    Java数组定义常用方法 Java中的数组.是一种简单的线性数据存储结构.他用牺牲自动扩展大小来换取与集合相比的唯一优势--查询效率的提升.Java中的数组有什么类型?我们要怎么定义这些数组呢?下面跟 ...

  7. 数组的常用方法(函数)

    一.数组的常用方法: 内置法:直接使用,只需按要求传递对应的参数 1.join(连接字符):作用是将数组中的元素通过给定的连接字符连成一个字符串 2.push(值/变量/对象):从数组的末尾向数组添加 ...

  8. 前端面试题总结之数组的常用方法(一)

    数组的常用方法有 Join  split  push pop unshift shift reverse sort 一.Join 就是将数组转化为字符串 arr.join("符号" ...

  9. JavaScript二维数组的常用方法及排序

    多维数组: 多维数组实际上就是数组的数组,指数组的每一元素也是一个数组: JavaScript中的二维数组的列的长度可以不唯一: 二维数组的创建: //创建已知的二维数组var multiArr=[[ ...

最新文章

  1. 性能调优常见问题与方案
  2. Minimax 和 Alpha-beta 剪枝算法简介,及以此实现的井字棋游戏(Tic-tac-toe)
  3. 一个超酷的横向多列响应式布局效果
  4. js的数据类型--数字
  5. 用pip安装tensorflow报错SyntaxError: invalid syntax
  6. 反向传播算法 Backpropagation Algorithm
  7. jenkins~集群分发功能的具体实现
  8. Linux 出现Permission denied的解决办法
  9. php重写html不刷新,html5,html_两个页面进行交互,如何实现页面不刷新就更改html?,html5,html,javascript,php - phpStudy...
  10. python seaborn boxplot_seaborn.boxplot
  11. 2020 ECCV 目标检测冠军
  12. 【Codeforces 1426 E】Rock, Paper, Scissors,贪心!算反面
  13. 【BERT】小学生级上手教程,从原理到上手全有图示,还能直接在线运行
  14. Linux服务器操作系统 . 文件目录及文件管理
  15. 工作中使用到的单词(软件开发)_2022-06-01备份
  16. 带你快速入门AXI4总线--AXI4-Full篇(2)----XILINX AXI4-Full接口IP源码仿真分析(Slave接口)
  17. 电脑硬件基础知识科普
  18. android画布橡皮,Android画板开发之橡皮擦功能
  19. 工具一栏,就是小锤子右边的一排都没亮
  20. leetcode/求平方根

热门文章

  1. 测试开发工作者日记:2020.9.21
  2. mc服务器rank称号系统,脚本控制称号的脚本分享!
  3. 常见快捷键eclipse
  4. 新生儿牛宝宝取名:俊俏、帅气、能力突出的男孩名字
  5. 2023年国漫前瞻:出海、漫改剧、元宇宙
  6. python 生成pdf页面大小,如何在reportlab,python中创建具有不同页面大小的PDF文档...
  7. 解决maven库中没有Oracle jdbc驱动的问题Cannot resolve com.oracle:ojdbc14:10.2.0.4.0 ; 驱动下载
  8. XS9950硬件替代TP9950 国产1CH模拟高清RX芯片
  9. 从零开发短视频电商 30分钟未支付订单自动关闭、七天自动确认收货等延迟任务问题
  10. 家装老总“傍”邓亚萍找到第一桶金