JavaScript常见数组方法,教你如何转置矩阵

  • 二、常见数组方法

    • 🌴栈和队列方法
  • 🌴检索方法

  • 🌴数组转字符串

  • 🌴其他方法

一、常见二维数组操作

=========================================================================

🌴创建与遍历


在前面的篇章中,已经学习了一维数组的各种创建方式,了解一维数组如何创建后,二维数组的创建就非常的简单了,只需将数组元素设置为数组即可。

在这里插入图片描述

💡 在创建完二维数组后,如何遍历二维数组中的元素,对其进行操作呢?

  • 一维数组可以利用for、for…in或for…of(ES6提供)进行遍历。

  • 二维数组只需在遍历数组后,再次遍历数组的元素即可。

另外,在Web项目开发中,还经常通过多维空数组添加元素的方式来创建多维数组。下面以添加二维空数组元素为例进行演示。

在这里插入图片描述

若要为二维数组元素(如arr[i][0])赋值,首先要保证添加的元素(如arr[i])已经被创建为数组,否则程序会报“Uncaught TypeError……”错误。

📌注意

在创建多维数组时,虽然JavaScript没有限制数组的维数,但是在实际应用中,为了便于代码阅读、调试和维护,推荐使用三维及以下的数组保存数据。

🌴【案例】二维数组转置


二维数组的转置指的是将二维数组横向元素保存为纵向元素。

在这里插入图片描述

代码实现思路:

  • 找规律:res[0][0] = arr[0][0]、res[0][1] = arr[1][0]、res[0][2] = arr[2][0]。

  • 得结论: res[i][j] = arr[j][i]。②

  • res数组长度=arr元素(如arr[0])的长度。③

  • res元素(如res[0])的长度=arr数组的长度。④

  • 按照③和④完成res的创建与遍历,按②进行转置。

为了让你们有成就感我就不贴代码了,有问题可以在评论区提出。其实矩阵完全可以存在数组里,以后做矩阵转置直接运行代码就行了。

二、常见数组方法

=======================================================================

🌴栈和队列方法


JavaScript中,除了前面讲解的添加与删除数组元素的方式外,还可以利用Array对象提供的方法,模拟栈和队列的操作。

  • 在数组的末尾或开头添加数组的新元素。

  • 在数组的末尾或开头删除数组元素。

在这里插入图片描述

  • push()和unshift()方法的返回值是新数组的长度。

  • pop()和shift()方法返回的是移出的数组元素。

🌴检索方法


在开发中,若要检测给定的值是否是数组,或是查找指定的元素在数组中的位置。

在这里插入图片描述

表中除了Array.isArray()方法外,其余方法默认都是从指定数组索引的位置开始检索,且检索方式与运算符“===”相同,即只有全等时才会返回比较成功的结果。

⭐includes()和Array.isArray()方法

在这里插入图片描述

  • includes()方法的第1个参数表示待查找的值。

  • includes()方法的第2个参数用于指定在数组中查找的下标。

  • 设置为大于数组长度时,数组不会被检索,直接返回false。

  • 设置为小于0的数时,则检索的索引位置等于数组长度加上指定的负数,若结果仍是小于0的数,则检索整个数组。

⭐indexOf()方法

indexOf()用于在数组中从指定下标位置,检索到的第一个给定值,存在则返回对应的元素下标,否则返回-1。

📌 注意

indexOf()方法的第2个参数用于指定开始查找的下标:

  • 当其值大于或等于数组长度时,直接返回-1。

  • 当其值为负数时,则查找的下标位置等于数组长度加上指定的负数,若结果仍是小于0的数,则检索整个数组。

⭐lastIndexOf()方法

Array对象提供的lastIndexOf()方法,用于在数组中从指定下标位置检索到的最后一个给定值的下标。与indexOf()检索方式不同的是,lastIndexOf()方法默认逆向检索,即从数组的末尾向数组的开头检索。

react和vue的比较

相同
1)vitual dom
2)组件化
3)props,单一数据流

不同点
1)react是jsx和模板;(jsx可以进行更多的js逻辑和操作)
2)状态管理(react)
3)对象属性(vue)
4)vue:view——medol之间双向绑定
5)vue:组件之间的通信(props,callback,emit)

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

可以进行更多的js逻辑和操作)
2)状态管理(react)
3)对象属性(vue)
4)vue:view——medol之间双向绑定
5)vue:组件之间的通信(props,callback,emit)

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

[外链图片转存中…(img-JSQL7xcX-1714299697989)]

  • 26
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值