js学习-8(数组、基本操作、常用方法归纳)

本文详细介绍了JavaScript中数组的基本操作和常用方法,包括创建数组、添加和获取元素、数组长度的修改,以及push、pop、unshift、shift、slice、splice、concat、join、reverse、sort等方法的使用。此外,还涵盖了数组的遍历方法如for循环、forEach、map、filter、every、some和reduce,以及indexOf、lastIndexOf、find、findIndex、Array.from、Array.of等其他方法的讲解。
摘要由CSDN通过智能技术生成

一、数组

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

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

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

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

二、数组的基本操作

数组的元素可以是任意的数据类型,也可以是对象,也可以是函数,也可以是数组。类型和长度都没有限制。

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

1、创建数组对象

方法一:字面量创建。

var arr = [1,2,3]

方法二:利用对象创建

var arr = new Array(参数);

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

var arr1 = new Array(); // 参数为空
var arr2 = new Array(4); // 参数为一个数值
var arr3 = new Array(15, 16, 17); // 参数为多个数值

console.log(typeof arr1);  // 输出结果:object

console.log("arr1 = " + arr1);
console.log("arr2 = " + arr2);
console.log("arr3 = " + arr3);

2、像数组中添加元素

语法:数组[索引] = 值

	var arr1 = [];
    // 向数组中添加元素
    arr[0] = 10;
    arr[1] = 33;
    arr[2] = 22;
    arr[3] = 44;

3、获取数组中的元素

语法:数组[索引]

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

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

	var arr = [21, 22, 23];

    console.log(arr[0]); // 输出结果:21
    console.log(arr[5]); // 输出结果:undefined

4、获取数组的长度

语法:数组的长度 = 数组.length

    var arr = [21, 22, 23];

    console.log(arr.length); // 输出结果:3

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

5、修改数组的长度

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

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

    特例:伪数组arguments的长度可以修改,但是不能修改里面的元素,后续会进行补充。。。。

	var arr1 = [11, 12, 13];
    var arr2 = [21, 22, 23];

    // 修改数组 arr1 的 length
    arr1.length = 1;
    console.log(JSON.stringify(arr1));      //输出为[11]

    // 修改数组 arr2 的 length
    arr2.length = 5;
    console.log(JSON.stringify(arr2));      //输出为[21,22,23,null,null]

三、数组的常用方法

基本方法

方法 描述 备注
push() 向数组的最后面插入一个或多个元素,返回结果为该数组新的长度 会改变原数组
pop() 删除数组中的最后一个元素,返回结果为被删除的元素 会改变原数组
unshift() 在数组最前面插入一个或多个元素,返回结果为该数组新的长度 会改变原数组
shift() 删除数组中的第一个元素,返回结果为被删除的元素 会改变原数组
1、push():在数组的最后面插入一个或多个元素,返回结果为该数组的长度。

语法:

数组的新长度 = 数组.push(元素);
	var arr = ["周震南", "姚琛", "张颜齐"];

    var result1 = arr.push("刘也"); // 末尾插入一个元素
    var result2 = arr.push("任豪", "赵让"); // 末尾插入多个元素

    console.log(result1); // 输出结果:4
    console.log(result2); // 输出结果:6
    console.log(JSON.stringify(arr)); // 输出结果:["周震南", "姚琛", "张颜齐","刘也","任豪", "赵让"]
2、pop():删除数组中的最后一个元素,返回结果为被删除的元素

语法:

 被删除的元素 = 数组.pop();
	var arr = ["周震南", "姚琛", "张颜齐"];

    var result1 = arr.pop();

    console.log(result1); // 输出结果:张颜齐
    console.log(JSON.stringify(arr)); // 打印结果:["周震南", "姚琛"]
3、unshift():在数组最前面插入一个或多个元素,返回结果为该数组新的长度。插入元素后,其他元素的索引会依次调整。

语法:

数组的新长度 = 数组.unshift(元素);
 	var arr = ["周震南", "姚琛", "张颜齐"];

    var result1 = arr.unshift("刘也"); // 最前面插入一个元素
    var result2 = arr.unshift("任豪", "赵让"); // 最前面插入多个元素

    console.log(result1); // 输出结果:4
    console.log(result2); 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript数组有很多内置方法,可以操作和处理数据。以下JavaScript数组的所有方法列表: 1. `concat()` - 连接两个或多个数组。 2. `copyWithin()` - 在数组内部将一段元素拷贝到另一个位置。 3. `entries()` - 返回一个迭代器对象,可以遍历数组所有的键值对。 4. `every()` - 检查数组中的所有元素是否满足一个条件。 5. `fill()` - 用静态值填充一个数组中的所有元素。 6. `filter()` - 通过指定条件过滤出符合条件的数组元素。 7. `find()` - 返回找到的第一个元素,满足条件。 8. `findIndex()` - 返回目标元素索引,满足条件。 9. `forEach()` - 遍历数组,对每个元素执行指定的操作。 10. `includes()` - 判断数组是否包含指定元素。 11. `indexOf()` - 返回指定元素第一个出现的位置索引。 12. `join()` - 连接数组元素,返回字符串。 13. `keys()` - 返回一个迭代器对象,可以遍历数组的键。 14. `lastIndexOf()` - 返回指定元素最后一次出现的位置索引。 15. `map()` - 遍历数组,对每个元素执行指定的操作,将结果放入新数组。 16. `pop()` - 删除数组最后一个元素。 17. `push()` - 在数组末尾添加一个或多个元素。 18. `reduce()` - 对数组中的每个元素执行指定的操作,累积计算并返回最终结果。 19. `reduceRight()` - 与reduce()方法类似,不过是从右到左遍历数组。 20. `reverse()` - 反转数组元素的顺序。 21. `shift()` - 删除数组的第一个元素。 22. `slice()` - 截取数组元素,返回新数组。 23. `some()` - 检查数组中是否存在至少一个元素满足一个条件。 24. `sort()` - 排序数组元素。 25. `splice()` - 删除、插入或替换数组中的元素。 26. `toString()` - 将数组转换成字符串。 27. `unshift()` - 在数组的开头添加一个或多个元素。 28. `valueOf()` - 返回数组本身。 以上方法中,有些方法会改变原数组,有些方法则不会。需要注意使用时,避免产生错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值