美文网首页
JavaScript (12)-数组

JavaScript (12)-数组

作者: 你的胡霸霸 | 来源:发表于2021-07-13 17:53 被阅读0次

    数组简介

    数组(Array)是属于内置对象,我们可以在MDN网站上查询各种方法。

    数组和普通对象的功能类似,也是用来存储一些值的。不同的是:

    普通对象是使用字符串作为属性名的,而数组是使用数字来作为索引来操作元素。索引:从0开始的整数就是索引。

    数组的存储性能比普通对象要好。在实际开发中我们经常使用数组来存储一些数据,使用频率非常高。

    数组的基本操作

    数组的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。

    数组的元素中,如果存放的是数组,我们就称这种数组为二维数组。

    创建数组对象

    方式一:字面量定义。举例:

    var arr=[1,2,3];

    方式二:对象定义(数组的构造函数)。

    语法:

    var arr = new Array(参数);

    如果参数为空,则表示创建一个空数组;参数位置是一个数值时,表示数组长度;参数位置是多个数值时,表示数组中的元素。

    上面的两种方式,我来举个例子:

    // 方式一

    var arr1=[11,12,13];

    // 方式二

    var arr2=new Array();// 参数为空

    var arr3=new Array(4);// 参数为一个数值

    var arr4=new Array(15,16,17);// 参数为多个数值

    console.log(typeof arr1);// 打印结果:object

    console.log("arr1 = "+JSON.stringify(arr1));

    console.log("arr2 = "+JSON.stringify(arr2));

    console.log("arr3 = "+JSON.stringify(arr3));

    console.log("arr4 = "+JSON.stringify(arr4));

    打印结果:

    object

    arr1=[11,12,13]

    arr2=[]

    arr3=[null,null,null,null]

    arr4=[15,16,17]

    从上方打印结果的第一行里,可以看出,数组的类型其实也是属于对象

    向数组中添加元素

    语法:

    数组[索引]=值

    代码举例:

    vararr1=[];

    // 向数组中添加元素

    arr[0]=10;

    arr[1]=33;

    arr[2]=22;

    arr[3]=44;

    获取数组中的元素

    语法:

    数组[索引]

    数组的索引代表的是数组中的元素在数组中的位置,从0开始。

    如果读取不存在的索引(比如元素没那么多),系统不会报错,而是返回undefined。

    代码举例:

    var arr=[21,22,23];

    console.log(arr[0]);// 打印结果:21

    console.log(arr[5]);// 打印结果:undefined

    获取数组的长度

    可以使用length属性来获取数组的长度(元素的个数)。

    语法:

    数组的长度=数组名.length;

    代码举例:

    var arr=[21,22,23];

    console.log(arr.length);// 打印结果:3

    补充:

    对于连续的数组,使用length可以获取到数组的长度(元素的个数);对于非连续的数组,使用length会获取到数组的最大的索引+1。因此,尽量不要创建非连续的数组。

    修改数组的长度(修改length)

    如果修改的length大于原长度,则多出部分会空出来,置为 null。

    如果修改的length小于原长度,则多出的元素会被删除,数组将从后面删除元素。

    (特例:伪数组arguments的长度可以修改,但是不能修改里面的元素,后面单独讲。)

    代码举例:

    va rarr1=[11,12,13];

    var arr2=[21,22,23];

    // 修改数组 arr1 的 length

    arr1.length=1;

    console.log(JSON.stringify(arr1));

    // 修改数组 arr2 的 length

    arr2.length=5;

    console.log(JSON.stringify(arr2));

    打印结果:

    [11]

    [21,22,23,null,null]

    数组的四个基本方法如下:(数组元素的添加和删除)

    方法描述备注

    push()向数组的最后面插入一个或多个元素,返回结果为该数组新的长度会改变原数组

    pop()删除数组中的最后一个元素,返回结果为被删除的元素会改变原数组

    unshift()在数组最前面插入一个或多个元素,返回结果为该数组新的长度会改变原数组

    shift()删除数组中的第一个元素,返回结果为被删除的元素会改变原数组

    数组的常见方法如下

    方法描述备注

    slice()从数组中提取指定的一个或多个元素,返回结果为新的数组不会改变原数组

    splice()从数组中删除指定的一个或多个元素,返回结果为新的数组会改变原数组

    concat()连接两个或多个数组,返回结果为新的数组不会改变原数组

    join()将数组转换为字符串,返回结果为转换后的字符串不会改变原数组

    reverse()反转数组,返回结果为反转后的数组会改变原数组

    sort()对数组的元素,默认按照Unicode编码,从小到大进行排序会改变原数组

    遍历数组的方法如下

    方法描述备注

    for循环这个大家都懂 

    forEach()和 for循环类似,但需要兼容IE8以上forEach() 没有返回值。也就是说,它的返回值是 undefined

    map()对原数组中的每一项进行加工,将组成新的数组不会改变原数组

    filter()对数组中每一项运行回调函数,该函数返回结果是true的项,将组成新的数组,返回结果为新的数组。可以起到过滤的作用不会改变原数组

    every()如果有一项返回false,则停止遍历,此方法返回 false一假即假。要求每一项都返回true,最终的结果才返回true

    some()只要有一项返回true,则停止遍历,此方法返回true一真即真。要求每一项都返回false,最终的结果才返回false

    reduce为数组中的每一个元素,依次执行回调函数 

    数组的其他方法如下

    方法描述备注

    indexOf(value)从前往后索引,获取 value 在数组中的第一个下标 

    lastIndexOf(value)从后往前索引,获取 value 在数组中的最后一个下标 

    find(function())找出第一个满足「指定条件返回true」的元素。 

    findIndex(function())找出第一个满足「指定条件返回true」的元素的index 

    Array.from(arrayLike)将伪数组转化为真数组 

    Array.of(value1, value2, value3)将一系列值转换成数组。

    相关文章

      网友评论

          本文标题:JavaScript (12)-数组

          本文链接:https://www.haomeiwen.com/subject/xwuspltx.html