迟早要知道的JS系列之常用数组方法

Posted eric021

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了迟早要知道的JS系列之常用数组方法相关的知识,希望对你有一定的参考价值。

常用数组方法

一.不会改变原始数组的方法:

即访问方法,下面的这些方法绝对不会改变调用它们的对象的值,只会返回一个新的数组或者返回一个其它的期望值。

1. concat()

** 语法:**
javascript,defaultvar new_array = old_array.concat(value1[, value2[, ...[, valueN]]])

参数: valueN(可选)
将数组和/或值连接成新数组。如果省略了valueN参数参数,则concat会返回一个它所调用的已存在的数组的浅拷贝

**返回值 **
返回新的数组实例。原始数组/值在连接时保持不变。此外,对于新数组的任何操作(仅当元素不是对象引用时)都不会对原始数组产生影响,反之亦然。

实例:

  let obj={a:1}
  const arr=["a","b",obj]; //obj为对象的引用,原始数组arr同新数组arr2引用相同对象,其更改对于原始数组和新数组是可见的
  const arr1=[1,2,3,4];
  const arr2=arr1.concat(obj);
  obj.a=2;               
  console.log(arr2);    	//[‘a‘,‘b‘,{a:2},1,2,3,4]  
  console.log(arr);       //[‘a‘,‘b‘,{a:2}]

2.slice()

** 语法:**
arr.slice(begin, end)

参数:
***begin(可选) ***
如果该参数为负数,则表示从原数组中的倒数第几个元素开始提取,slice(-2) 表示提取原数组中的倒数第二个元素到最后一个元素(包含最后一个元素)。

如果省略 begin,则 slice 从索引 0 开始。

如果 begin 大于原数组的长度,则会返回空数组。

***end(可选) ***
在该索引处结束提取原数组元素。slice 会提取原数组中索引从 begin 到 end 的所有元素(包含 begin,但不包含 end)。
slice(1,4) 会提取原数组中从第二个元素开始一直到第四个元素的所有元素 (索引为 1, 2, 3的元素)。

如果该参数为负数, 则它表示在原数组中的倒数第几个元素结束抽取。 slice(-2,-1) 表示抽取了原数组中的倒数第二个元素到最后一个元素(不包含最后一个元素,也就是只有倒数第二个元素)。

如果 end 被省略,则 slice 会一直提取到原数组末尾。

如果 end 大于数组的长度,slice 也会一直提取到原数组末尾.

**返回值 **
slice 不会修改原数组,只会返回一个浅复制了原数组中的元素的一个新数组。拷贝规则同concat()

实例:

  var fruits = [‘Banana‘, ‘Orange‘, ‘Lemon‘, ‘Apple‘, ‘Mango‘];
  var citrus = fruits.slice(1, 3);

// fruits contains [‘Banana‘, ‘Orange‘, ‘Lemon‘, ‘Apple‘, ‘Mango‘]
// citrus contains [‘Orange‘,‘Lemon‘]

3.join()

语法:
arr.join([separator])
**参数: ** separator(可选)
指定一个字符串来分隔数组的每个元素。如果需要,将分隔符转换为字符串。如果缺省该值,数组元素用逗号(,)分隔。如果separator是空字符串(""),则所有元素之间都没有任何字符

**返回值 **
将一个数组(或一个类数组对象)的所有元素连接成一个字符串并返回这个字符串。如果数组只有一个项目,那么将返回该项目而不使用分隔符。如果 arr.length 为0,则返回空字符串

实例:

  var a = [‘Wind‘, ‘Rain‘, ‘Fire‘];
  var myVar1 = a.join();      // myVar1的值变为"Wind,Rain,Fire"
  var myVar2 = a.join(‘, ‘);  // myVar2的值变为"Wind, Rain, Fire"
  var myVar3 = a.join(‘ + ‘); // myVar3的值变为"Wind + Rain + Fire"
  var myVar4 = a.join(‘‘);    // myVar4的值变为"WindRainFire"

4.toString()

** 语法:**
arr.toString()

**返回值 **
返回一个字符串,表示指定的数组及其元素。

实例:

   const array1 = [1, 2, ‘a‘, ‘1a‘];
   console.log(array1.toString());
// "1,2,a,1a"

5.indexof()

** 语法:**
arr.indexOf(searchElement,fromIndex)

参数:
***searchElement ***
要查找的元素

fromIndex(可选)
开始查找的位置。如果该索引值大于或等于数组长度,意味着不会在数组里查找,返回-1。

如果参数中提供的索引值是一个负值,则将其作为数组末尾的一个抵消,即-1表示从最后一个元素开始查找,-2表示从倒数第二个元素开始查找 ,以此类推。

注意:如果参数中提供的索引值是一个负值,并不改变其查找顺序,查找顺序仍然是从前向后查询数组。

如果抵消后的索引值仍小于0,则整个数组都将会被查询。其默认值为0

**返回值 **
返回在数组中可以找到一个给定元素的第一个索引,如果不存在,则返回-1

实例:

var array = [2, 5, 9];
array.indexOf(2);     // 0
array.indexOf(7);     // -1
array.indexOf(9, 2);  // 2
array.indexOf(2, -1); // -1
array.indexOf(2, -3); // 0  

6.lastIndexOf()

** 语法:**
arr.lastIndexOf(searchElement,fromIndex)
参数:
***searchElement ***
要查找的元素

fromIndex(可选)
从此位置开始逆向查找。默认为数组的长度减 1(arr.length - 1),即整个数组都被查找。

如果该值大于或等于数组的长度,则整个数组会被查找。

如果为负值,将其视为从数组末尾向前的偏移。即使该值为负,数组仍然会被从后向前查找。

如果该值为负时,其绝对值大于数组长度,则方法返回 -1,即数组不会被查找。

**返回值 **
返回指定元素(也即有效的 JavaScript 值或变量)在数组中的最后一个的索引,如果不存在则返回 -1。从数组的后面向前查找,从 fromIndex 处开始。

实例:

var array = [2, 5, 9, 2];
var index = array.lastIndexOf(2);
// index is 3
index = array.lastIndexOf(7);
// index is -1
index = array.lastIndexOf(2, 3);
// index is 3
index = array.lastIndexOf(2, 2);
// index is 0
index = array.lastIndexOf(2, -2);
// index is 0
index = array.lastIndexOf(2, -1);
// index is 3

二.会改变原始数组的方法:

下面的这些方法会改变调用它们的对象自身的值:

1.splice()

** 语法:**
array.splice(start,deleteCount, item1,item2, ..)
参数:
*** start***
指定修改的开始位置(从0计数)。如果超出了数组的长度,则从数组末尾开始添加内容;

如果是负值,则表示从数组末位开始的第几位(从-1计数,这意味着-n是倒数第n个元素并且等价于array.length-n);

如果负数的绝对值大于数组的长度,则表示开始位置为第0位。

*** deleteCount(可选)***
整数,表示要移除的数组元素的个数。
如果 deleteCount 大于 start 之后的元素的总数,则从 start 后面的元素都将被删除(含第 start 位)。

如果 deleteCount 被省略了,或者它的值大于等于array.length - start(也就是说,如果它大于或者等于start之后的所有元素的数量),那么start之后数组的所有元素都会被删除。

如果 deleteCount 是 0 或者负数,则不移除元素。这种情况下,至少应添加一个新元素。

**返回值 **
通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容,如果只删除了一个元素,则返回只包含一个元素的数组。

如果没有删除元素,则返回空数组。此方法会改变原数组。

实例:

//1.从第 2 位开始删除 0 个元素,插入“drum”
var myFish = ["angel", "clown", "mandarin",    "sturgeon"];    //1-5同
var removed = myFish.splice(2, 0, "drum");

// 运算后的 myFish: ["angel", "clown", "drum", "mandarin", "sturgeon"]
// 被删除的元素: [], 没有元素被删除    --removed的返回值下同

//2.从第 2 位开始删除 0 个元素,插入“drum” 和 "guitar"
var removed = myFish.splice(2, 0, ‘drum‘, ‘guitar‘);

// 运算后的 myFish: ["angel", "clown", "drum", "guitar", "mandarin", "sturgeon"]
// 被删除的元素: [], 没有元素被删除

//3.从第 3 位开始删除 1 个元素
var removed = myFish.splice(3, 1);

// 运算后的 myFish: ["angel", "clown", "drum", "sturgeon"]
// 被删除的元素: ["mandarin"]

//4.从第 2 位开始删除 1 个元素,插入“trumpet”
var removed = myFish.splice(2, 1, "trumpet");

// 运算后的 myFish: ["angel", "clown", "trumpet", "sturgeon"]
// 被删除的元素: ["drum"]

//5.从第 0 位开始删除 2 个元素,插入"parrot"、"anemone"和"blue"
var removed = myFish.splice(0, 2, ‘parrot‘, ‘anemone‘, ‘blue‘);

// 运算后的 myFish: ["parrot", "anemone", "blue", "trumpet", "sturgeon"]
// 被删除的元素: ["angel", "clown"]

//6.从第 2 位开始删除 2 个元素
var myFish = [‘parrot‘, ‘anemone‘, ‘blue‘, ‘trumpet‘, ‘sturgeon‘];
var removed = myFish.splice(myFish.length - 3, 2);

// 运算后的 myFish: ["parrot", "anemone", "sturgeon"]
// 被删除的元素: ["blue", "trumpet"]

//7.从倒数第 2 位开始删除 1 个元素
var myFish = [‘angel‘, ‘clown‘, ‘mandarin‘, ‘sturgeon‘];
var removed = myFish.splice(-2, 1);

// 运算后的 myFish: ["angel", "clown", "sturgeon"]
// 被删除的元素: ["mandarin"]

//8.从第 2 位开始删除所有元素
var myFish = [‘angel‘, ‘clown‘, ‘mandarin‘, ‘sturgeon‘];
var removed = myFish.splice(2);

// 运算后的 myFish: ["angel", "clown"]
// 被删除的元素: ["mandarin", "sturgeon"]

2.pop()

** 语法:**
arr.pop()

**返回值 **
从数组中删除最后一个元素,并返回该元素的值。此方法更改数组的长度。当数组为空时返回undefined

实例:

let myFish = ["angel", "clown", "mandarin", "surgeon"];

let popped = myFish.pop();

console.log(myFish); 
// ["angel", "clown", "mandarin"]

console.log(popped); 
// surgeon

3.push()

** 语法:**
arr.push(element1, ..., elementN)

参数:
elementN
被添加到数组末尾的元素。

返回值 **
将一个或多个元素添加到数组的末尾,并返回该数组的新长度。
新的 length 属性值将被返回。**

实例:

var sports = ["soccer", "baseball"];
var total = sports.push("football", "swimming");

console.log(sports); 
// ["soccer", "baseball", "football", "swimming"]

console.log(total);  

4.shift()

** 语法:**
arr.shift()

**返回值 **
从数组中删除第一个元素,并返回该元素的值。此方法更改数组的长度。如果数组为空则返回undefined

实例:

let myFish = [‘angel‘, ‘clown‘, ‘mandarin‘, ‘surgeon‘];

console.log(‘调用 shift 之前: ‘ + myFish);
// "调用 shift 之前: angel,clown,mandarin,surgeon"

var shifted = myFish.shift(); 

console.log(‘调用 shift 之后: ‘ + myFish); 
// "调用 shift 之后: clown,mandarin,surgeon" 

console.log(‘被删除的元素: ‘ + shifted); 
// "被删除的元素: angel"

5.unshift()

** 语法:**
arr.unshift(element1, ..., elementN)

参数:
elementN
要添加到数组开头的元素或多个元素。

返回值 **
将一个或多个元素添加到数组的开头,并
返回该数组的新长度**(该方法修改原有数组)。当一个对象调用该方法时,返回其 length 属性值。

实例:

let arr = [1, 2];

arr.unshift(0); // result of the call is 3, which is the new array length
// arr is [0, 1, 2]

arr.unshift(-2, -1); // the new array length is 5
// arr is [-2, -1, 0, 1, 2]

arr.unshift([-4, -3]); // the new array length is 6
// arr is [[-4, -3], -2, -1, 0, 1, 2]

arr.unshift([-7, -6], [-5]); // the new array length is 8
// arr is [ [-7, -6], [-5], [-4, -3], -2, -1, 0, 1, 2 ]

6.reverse()

** 语法:**
arr.reverse()

**返回值 **
颠倒后的数组。 将数组中元素的位置颠倒,并返回该数组。数组的第一个元素会变成最后一个,数组的最后一个元素变成第一个。该方法会改变原数组。

实例:

const array1 = [‘one‘, ‘two‘, ‘three‘];
console.log(‘array1:‘, array1);
// expected output: "array1:" Array ["one", "two", "three"]

const reversed = array1.reverse();
console.log(‘reversed:‘, reversed);
// expected output: "reversed:" Array ["three", "two", "one"]

// Careful: reverse is destructive -- it changes the original array.
console.log(‘array1:‘, array1);
// expected output: "array1:" Array ["three", "two", "one"]

7.sort()

** 语法:**
arr.sort(function(a,b){....})

参数
function(){}可选
用来指定按某种顺序进行排列的函数。如果省略,元素按照转换为的字符串的各个字符的Unicode位点进行排序。

a
第一个用于比较的元素。

b
第二个用于比较的元素。

如果指明了 compareFunction(即function(a,b)) ,那么数组会按照调用该函数的返回值排序。即 a 和 b 是两个将要被比较的元素:

  • 如果 compareFunction(a, b) 小于 0 ,那么 a 会被排列到 b 之前;

  • 如果 compareFunction(a, b) 等于 0 , a 和 b 的相对位置不变。备注: ECMAScript 标准并不保证这一行为,而且也不是所有浏览器都会遵守(例如 Mozilla 在 2003 年之前的版本);

  • 如果 compareFunction(a, b) 大于 0 , b 会被排列到 a 之前。

  • compareFunction(a, b) 必须总是对相同的输入返回相同的比较结果,否则排序的结果将是不确定的。

**返回值 **
用原地算法对数组的元素进行排序,并返回数组。默认排序顺序是在将元素转换为字符串,然后比较它们的UTF-16代码单元值序列时构建的

//比较函数格式如下
function compare(a, b) {
  if (a < b ) {           // 按某种排序标准进行比较, a 小于 b
    return -1;    
  }
  if (a > b ) {
    return 1;
  }
  // a must be equal to b
  return 0;
}

实例:

var numbers = [4, 2, 5, 1, 3];
numbers.sort(function(a, b) {
  return a - b;
});
console.log(numbers);

也可以写成:
var numbers = [4, 2, 5, 1, 3]; 
numbers.sort((a, b) => a - b); 
console.log(numbers);

// [1, 2, 3, 4, 5]

参考:
https://developer.mozilla.org/zh-CN/

以上是关于迟早要知道的JS系列之常用数组方法的主要内容,如果未能解决你的问题,请参考以下文章

值得收藏面试会用到的十个常用的数组方法JS实现

值得收藏面试会用到的十个常用的数组方法JS实现

网络相关系列之三:通过GET和POST方法发送数据

JS常用代码片段-127个常用罗列-值得收藏

杨老师课堂之ArrayList集合常用方法解析

javascript常用代码片段