工作中经常会遇到数组,所以就总结了一下数组的相关知识~


Array对象

  • 定义
  • 创建数组
  • 属性
  • `constructor`
  • `length`
  • `prototype`
  • 数组方法
  • concat
  • join
  • pop
  • push
  • reverse
  • shift
  • slice
  • sort
  • splice
  • indexOf
  • toString
  • isArray
  • unshift
  • valueOf
  • lastIndexOf


定义

Array 对象用于在单个的变量中存储多个值。

创建数组

(1)使用Array构造函数创建数组:

var arr1 = new Array();
var arr2 = new Array(5);
var arr3 = new Array("one","two","three","four");

上面例子中,第一行创建了一个空数组;

第二行创建了一个长度为5,包含5项的数组;

第三行创建了一个包含四个字符串的数组。

(2)使用数组字面量表示法创建数组:

var arr1 = [];
var arr2 = [5];
var arr3 = ["one","two","three","four"];

属性

constructor

(1)constructor:返回创建数组对象的原型函数

var arr = ["one","two","three","four"];
console.log(arr.constructor);
运行结果:
ƒ Array() { [native code] }

length

(2)length:设置或返回数组元素的个数

var arr = ["one","two","three","four"];
console.log(arr.length);
运行结果:
4

也可以使用 length 来设置数组的个数:

var arr = ["one","two","three","four"];
console.log(arr.length);
arr.length = 3;
console.log(arr);
console.log(arr.length);
运行结果:
4
["one", "two", "three"]
3

prototype

(3)prototype:允许向数组对象添加属性或方法

a)向对象添加属性

function stu(name,age,grade)
{
	this.name = name;
	this.age = age;
	this.grade = grade;
}

let obj = new stu("Jake",8,"three");

stu.prototype.sex = null;
obj.sex = "male";

console.log(obj.sex);
运行结果:
male

b)向对象添加方法:

Array.prototype.toUcase=function()
{
    for (i=0;i<this.length;i++)
    {
        this[i]=this[i].toUpperCase();
    }
}
var arr = ["one", "Two", "three", "four"];
arr.toUcase();
console.log(arr);
运行结果:
["ONE", "TWO", "THREE", "FOUR"]

数组方法

concat

(1)concat():连接两个或多个数组,并返回结果

a)数组连接元素:

var arr = [45,1,59,26,47,2,12,45,9,71,23];
console.log(arr.concat(10,20));
console.log(arr);
运行结果:
VM1539:2 (13) [45, 1, 59, 26, 47, 2, 12, 45, 9, 71, 23, 10, 20]
VM1539:3 (11) [45, 1, 59, 26, 47, 2, 12, 45, 9, 71, 23]

b)连接两个数组:

var arr1 = [2,3,4];
var arr2 = [5,4,6];
console.log(arr1.concat(arr2));
console.log(arr1);
console.log(arr2);
运行结果:
VM1520:3 (6) [2, 3, 4, 5, 4, 6]
VM1520:4 (3) [2, 3, 4]
VM1520:5 (3) [5, 4, 6]

c)连接三个数组:

var arr1 = [2,3,4];
var arr2 = [5,4,6];
var arr3 = [7,8,9];
console.log(arr1.concat(arr2,arr3));
console.log(arr1);
console.log(arr2);
console.log(arr3);
运行结果:
VM1660:4 (9) [2, 3, 4, 5, 4, 6, 7, 8, 9]
VM1660:5 (3) [2, 3, 4]
VM1660:6 (3) [5, 4, 6]
VM1660:7 (3) [7, 8, 9]

上面的三个例子可以看到,连接数组之后,原来的数组没有改变,返回的是被连接数组的一个副本。

join

(2)join():把数组的所有元素放入一个字符串,元素通过指定的分隔符进行分隔。

a)将数组的元素放进一个字符串:

var arr = ["one", "Two", "three", "four"];
console.log(arr.join());
console.log(arr);
运行结果:
VM1951:2 one,Two,three,four
VM1951:3 (4) ["one", "Two", "three", "four"]

b)将数组的元素放进一个字符串,并且用“.”分开:

var arr = ["one", "Two", "three", "four"];
console.log(arr.join("."));
console.log(arr);
运行结果:
VM1977:2 one.Two.three.four
VM1977:3 (4) ["one", "Two", "three", "four"]

c)将数组的元素放进一个字符串,并且用“-”分开:

var arr = ["one", "Two", "three", "four"];
console.log(arr.join("-"));
console.log(arr);
运行结果:
VM1984:2 one-Two-three-four
VM1984:3 (4) ["one", "Two", "three", "four"]

d)join() 方法可以用来实现字符串重复:

function changeStr(str,n){
    return new Array(n+1).join(str);
}
console.log(changeStr("one",5));
运行结果:
VM3927:4 oneoneoneoneone

pop

(3)pop():删除并返回数组的最后一个元素

var arr = ["one", "Two", "three", "four"];
console.log(arr.pop());
console.log(arr);
运行结果:
VM2063:2 four
VM2063:3 (3) ["one", "Two", "three"]

上面的例子可以看出,对数组使用pop()方法后,返回了数组的最后一个元素,且数组的最后一个元素被删除了。

push

(4)push(): 向数组的末尾添加元素,并返回新的长度。

var arr = ["one", "Two", "three", "four"];
console.log(arr.push("five"));
console.log(arr);
运行结果:
VM2106:2 5
VM2106:3 (5) ["one", "Two", "three", "four", "five"]

可以看到,对数组使用push()方法,在数组的末尾添加了元素,原数组改变。

reverse

(5)reverse():颠倒数组中元素的顺序

var arr = ["one", "Two", "three", "four"];
console.log(arr.reverse());
console.log(arr);
运行结果:
VM2313:2 (4) ["four", "three", "Two", "one"]
VM2313:3 (4) ["four", "three", "Two", "one"]

可以看到,原数组发生了反转。

shift

(6)shift():删除并返回数组的第一个元素

var arr = ["one", "Two", "three", "four"];
console.log(arr.shift());
console.log(arr);
运行结果:
VM2180:2 one
VM2180:3 (3) ["Two", "three", "four"]

可以看到,对数组使用shift()返回的是数组的第一个元素,且原数组发生了变化,数组的第一个元素被删除了。

slice

(7)slice():从已有的数组返回选定的元素

slice() 函数的语法为:slice(start,end),表示从数组中选取从 start 到 end (不包含end位置的元素)的元素,并且返回一个新的数组,原数组不会被修改;也可以截取字符串中指定的部分,并返回一个新的字符串。

a)end 为空,返回从 start 到数组的结尾的元素:

var arr = ["one", "Two", "three", "four"];
console.log(arr.slice(1));
console.log(arr);
运行结果:
VM2356:2 (3) ["Two", "three", "four"]
VM2356:3 (4) ["one", "Two", "three", "four"]

上面的例子返回了一个从 start 开始到数组结尾的新的数组。

b)返回从 start 到 end(不包含end)的元素:

var arr = ["one", "Two", "three", "four"];
console.log(arr.slice(1,3));
console.log(arr);
运行结果:
VM2389:2 (2) ["Two", "three"]
VM2389:3 (4) ["one", "Two", "three", "four"]

上面的例子返回了一个从 start 开始到 end 的新的数组,而且,要注意的一点是:这里面不包含 end。

c)截取字符串中的元素

var str = "abcdefghijklmnopq";
console.log(str.slice(4,8));
console.log(str);
运行结果:
VM2597:2 efgh
VM2597:3 abcdefghijklmnopq

上面例子截取了字符串中指定 start 到 end(不包含end)的元素,并返回了一个新的字符串,原来的字符串并没有被改变。

d)start、end 为负数,规定规定从数组尾部开始算起的位置。例如:-1 指倒数第一个元素,-3 指倒数第三个元素。

var arr = ["one", "Two", "three", "four"];
console.log(arr.slice(-3,-1));
console.log(arr);
运行结果:
VM2652:2 (2) ["Two", "three"]
VM2652:3 (4) ["one", "Two", "three", "four"]

sort

(8)sort():对数组的元素进行排序,默认是按照字母升序的顺序排列

var arr = ["one", "Two", "three", "four","five"];
console.log(arr.sort());
console.log(arr);
运行结果:
VM2717:2 (5) ["Two", "five", "four", "one", "three"]
VM2717:3 (5) ["Two", "five", "four", "one", "three"]

上面这个例子,是对数组中的元素进行了排序。

如果想要按照字母降序排列,可以使用 reverse() 方法,如下所示:

var arr = ["one", "Two", "three", "four","five"];
console.log(arr.sort().reverse());
console.log(arr);
运行结果:
VM2776:2 (5) ["three", "one", "four", "five", "Two"]
VM2776:3 (5) ["three", "one", "four", "five", "Two"]

哈哈,这种方法实现起来很方便呢~

sort() 方法是对数组元素按照字母升序进行排列,如果数组中是数字,会发生什么情况呢?

var arr = [45,1,59,26,47,2,12,45,9,71,23];
console.log(arr.sort());
console.log(arr);
运行结果:
VM2740:2 (11) [1, 12, 2, 23, 26, 45, 45, 47, 59, 71, 9]
VM2740:3 (11) [1, 12, 2, 23, 26, 45, 45, 47, 59, 71, 9]

可以看到,数组中是数组时,sort() 方法对数组进行排序,是按照字符编码进行排序的,并没有达到想要的按照数字大小排序的效果。这时候,如果要实现按照数字大小排序,则应该提供比较函数对数组进行排序。如下所示:

a)对数组中中的数字元素按照从小到大的顺序进行排序:

function sortNum(a, b)
{
	return a - b;
}
var arr = [45,1,59,26,47,2,12,45,9,71,23];
arr.sort(sortNum);
console.log(arr);
运行结果:
[1, 2, 9, 12, 23, 26, 45, 45, 47, 59, 71]

b)对数组中中的数字元素按照从大到小的顺序进行排序:

function sortNum(a,b){
	return b-a;
}
var arr = [45,1,59,26,47,2,12,45,9,71,23];
console.log(arr.sort(sortNum));
console.log(arr);
运行结果:
VM3097:5 (11) [71, 59, 47, 45, 45, 26, 23, 12, 9, 2, 1]
VM3097:6 (11) [71, 59, 47, 45, 45, 26, 23, 12, 9, 2, 1]

当然,也可以使用 reverse() 方法:

function sortNum(a,b){
	return a-b;
}
var arr = [45,1,59,26,47,2,12,45,9,71,23];
console.log(arr.sort(sortNum).reverse());
console.log(arr);
运行结果:
VM3134:5 (11) [71, 59, 47, 45, 45, 26, 23, 12, 9, 2, 1]
VM3134:6 (11) [71, 59, 47, 45, 45, 26, 23, 12, 9, 2, 1]

splice

(9)splice():删除元素,并向数组添加新元素

语法:splice(index,howmany,item1,…,itemX)

其中,index 表示开始删除元素的位置;

howmany 表示删除元素的个数;

item1,…,itemX 表示向数组中插入的元素。

a)从数组中删除元素:

var arr = ["one", "Two", "three", "four","five","six"];
console.log(arr.splice(3,2));
console.log(arr);
运行结果:
VM3362:2 (2) ["four", "five"]
VM3362:3 (4) ["one", "Two", "three", "six"]

上面例子删除了数组从index 3 开始的 2 个元素(注意,数组 index 是从 0 开始的)可以看出,对数组应用 splice() 方法之后,返回删除的元素,原数组也发生了变化。

b)数组添加元素:

var arr = ["one", "Two", "three", "four","five","six"];
console.log(arr.splice(3,0,"apple","pear","banala"));
console.log(arr);
运行结果:
VM3425:2 []
VM3425:3 (9) ["one", "Two", "three", "apple", "pear", "banala", "four", "five", "six"]

上面例子删除了从 index 3 开始的 0 个元素,并且在该位置插入了三个元素,原数组被改变。

c)数组删除元素并添加元素:

var arr = ["one", "Two", "three", "four","five","six"];
console.log(arr.splice(3,2,"apple","pear","banala"));
console.log(arr);
运行结果:
VM3450:2 (2) ["four", "five"]
VM3450:3 (7) ["one", "Two", "three", "apple", "pear", "banala", "six"]

上面例子删除了从 index 3 开始的 2 个元素并返回,且在原数组 index 3 开始添加了三个元素,原数组发生了改变。

indexOf

(10)indexOf() :返回数组中某个指定元素的位置

var arr = ["one", "Two", "three", "four","five","six"];
console.log(arr.indexOf("three"));
运行结果:
VM3607:2 2

上面例子返回了指定元素的位置。

如果数组中没有找到该元素,则会返回 -1。

var arr = ["one", "Two", "three", "four","five","six"];
console.log(arr.indexOf("apple"));
运行结果:
VM3618:2 -1

toString

(11)toString():把数组转换为字符串,并返回结果

var arr = ["one", "Two", "three", "four"];
console.log(arr.toString());
console.log(arr);
运行结果:
VM3286:2 one,Two,three,four
VM3286:3 (4) ["one", "Two", "three", "four"]

上面例子可以看出,数组使用 toString() 方法后,返回了一个字符串,但是原数组没有被改变。

isArray

(12)isArray():判断一个对象是否为数组

var arr = [2,3,4];
var obj = {};
console.log(Array.isArray(arr));
console.log(Array.isArray(obj));
运行结果:
VM1851:3 true
VM1851:4 false

unshift

(13)unshift():向数组的开头添加元素,并返回新的长度

var arr = ["one", "Two", "three", "four"];
console.log(arr.unshift("eone"));
console.log(arr);
运行结果:
VM2218:2 5
VM2218:3 (5) ["eone", "one", "Two", "three", "four"]

上面这个例子,给数组开头添加了一个元素,原数组发生了改变。

valueOf

(14)valueOf():返回数组对象的原始值

var arr = ["one", "Two", "three", "four"];
console.log(arr.valueOf());
运行结果:
VM2031:2 (4) ["one", "Two", "three", "four"]

lastIndexOf

(15)lastIndexOf():返回一个指定的元素在数组中最后出现的位置,从该字符串的后面向前查找。

var arr = ["one", "Two", "three", "four","Two","five","six","Two"];
console.log(arr.lastIndexOf("Two"));
运行结果:
VM4072:2 7