Js Array的使用
今天系统性的重温下Array对象的知识
定义
数组的定义:一个存储元素的线性集合,元素可以通过索引来任意存取,索引通常是数字,用来计算元素之间存储位置的偏移量。即数组对象用来在单独的变量名中存储一系列的值。
使用数组
创建数组
- 通过
var arr1 = [1,2,3]
- 通过 new
var arr2 = new Array(1,2,3)
(注意:如果里面传入的是一个数字,比如10,是定义一个length为10的数组,每一个元素都是undefined
)
读写数组
|
|
我们可以用[]
读取到索引的数组,同时也可以对他进行赋值改变的操作。
由字符串生成数组
调用字符串对象split()
方法通过一个字符串生成一个数组
|
|
对数组进行整体操作
把一个数组赋给另一个数组
|
|
存取函数
查找元素
indexOf()
是最常用的了,他授受一个参数,然后查找数组中元素等于这个参数值的第一个元素,返回对应的索引值,如果没有找到这个参数,返回-1
,如果有多个,返回第一个索引值
|
|
还有一个对应的函数lastIndexOf()
,他是从后面查起,对于多个,会返回查找到的第一个索引值。
|
|
数组的字符串表示
把数组转换成一个字符串有两个方法:toString()
和join()
前者是生成用,
分割开每个元素的字符串,后者可以传入一个参数来指导用空上参数值来隔开。
join()
将数组中所有元素都转化为字符串并连接在一起,默认分隔符是’,’,可以指定分隔符
|
|
由已有的数组创建新数组
方法有:concat()
和splice()
和slice()
concat()
接受多个数组作为参数,返回和他们合并的一个数组;splice()
截取一个数组的子集返回一个新数组;(会改变原数组)slice()
截取一个数组的子集:
|
|
|
|
数组方法
为数组增减元素
push()
将一个元素添加到数组的末尾,返回被添加的元素;unshift()
在数组首部添加一个或者多个元素,添加的顺序从参数尾部向前添加pop()
删除数组末尾的一个元素,返回这个元素值;shift()
删除数组开头的一个元素,返回这个元素值;
|
|
在数组中间添加或者删除元素
还是splice()
方法,他接受参数:
- 启始索引
- 需要删除的数组个数(添加元素的时候可以是0)
- 需要添加进数组的元素
|
|
为数组排序
reverse()
反转数组。数组元素顺序反转,返回反转后的数组,此过程在原数组进行,不创建新数组sort()
排序,可以授受一个排序规则函数作为参数
|
|
迭代方法
不生成新的数组的迭代器方法
forEach()
,他接受一个函数作为参数,函数接受两个参数:当前元素值、当前元素索引,单纯遍历数组。forEach无法用break中途停止遍历。
|
|
every()
接受一个返回值为布尔类型的函数为参数,对数组中每个元素使用该函数,如果全都是返回true
则该方法返回true
,如果有一个以上返回false
,那么该方法返回false
;
|
|
some()
方法,其实和every()
方法很像,顾名思义,如果返回的有一个结果是true
则返回true
,如果全是false
,则返回false
;
|
|
reduce()
方法,他接受两个参数:一个函数、一个初始值(可不传),函数接受4个参数:之前一次遍历的返回值(第一次的话就是初始值)、当前元素值、当前元素索引、被遍历的数组,函数返回一个值。他会从一个累加之开始不断对后面的元素调用该函数;
|
|
reduceRight()
方法,它其实和reduce()
方法一样,区别是他是从数组的右边开始累加到左边的。
生成新数组的方法
map()
方法授受一个函数,这个函数处理每一个元素并返回一个新的值 ,然后方法会返回这些值组成的一个新数组;
|
|
filter()
方法接受一个函数,函数返回一个布尔型的值,最后方法返回的数组是被函数返回true
的元素的集合,顾名思义,就是过滤
|
|
二维数组和多维数组
创建二维数组
二维数组类似于一种行和列组成的数据表格。
在javascript里面定义二维数组,可以扩展javascript的数组对象:
|
|
处理二位数组中的元素
|
|
是否改变原数组
- 1.不改变原有数组:
- indexOf
- lastIndexOf
- toString
- join
- concat
- slice
- some
- forEach
- every
- filter
- map
- reduce
- reduceRight
- 2.改变数组:
- splice
- push
- pop
- shift
- unshift
- reverse
- sort
es6中array的新特性
Array.from()
Array.from()
方法可以将两类对象转为直接的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括ES6新增的数据结构Set和Map)
下面是一个类似数组的对象,Array.from将它转为真正的数组。
|
|
Array.of()
Array.of()
方法用于将一组值,转换为数组
这个方法的主要目的,是弥补数组构造函数Array()的不足。因为参数个数的不同,会导致Array()的行为有差异。
就是之前说的在用 new 构造一个数组的时候,如果传入的是一个数字,那么返回的是一个该长度的数组:
|
|
如果使用 Array.of
:
|
|
数组实例的copyWithin()
数组实例的copyWithin方法,在当前数组内部,将指定位置的成员复制到其他位置(会覆盖原有成员),然后返回当前数组。也就是说,使用这个方法,会修改当前数组。
它接受三个参数:
- target(必需):从该位置开始替换数据。
- start(可选):从该位置开始读取数据,默认为0。如果为负值,表示倒数。
- end(可选):到该位置前停止读取数据,默认等于数组长度。如果为负值,表示倒数。
|
|
数组实例的find()和find
数组实例的find方法,用于找出第一个符合条件的数组成员。它的参数是一个回调函数,所有数组成员依次执行该回调函数,直到找出第一个返回值为true的成员,然后返回该成员。如果没有符合条件的成员,则返回undefined
|
|
数组实例的findIndex方法的用法与find方法非常类似,返回第一个符合条件的数组成员的位置,如果所有成员都不符合条件,则返回-1。
|
|
数组实例fill()
fill()
方法使用给定值,填充一个数组
|
|
fill()方法还可以接受第二个和第三个参数,用于指定填充的起始位置和结束位置
|
|
数组实例的entries(),keys()和values()
ES6提供三个新的方法——entries(),keys()和values()——用于遍历数组。
|
|
数组实例的includes()
Array.prototype.includes
方法返回一个布尔值,表示某个数组是否包含给定的值,与字符串的includes方法类似。该方法属于ES7,但Babel转码器已经支持。
|
|
该方法的第二个参数表示搜索的起始位置,默认为0。如果第二个参数为负数,则表示倒数的位置,如果这时它大于数组长度(比如第二个参数为-4,但数组长度为3),则会重置为从0开始。
|
|