JavaScript中伪数组变真数组

JavaScript中伪数组变真数组


首先介绍两种非常简单直接的方法(伪数组为可迭代对象):

  1. [...伪数组] // ES6的语法糖,直接将伪数组(对象)变为真数组

  2. Array.from(伪数组) // Array中的静态方法,直接将伪数组(对象)变为真数组


下面讲解伪数组和真数组的区别,还有利用数组的方法将伪数组变为真数组:

伪数组与真数组的区别:

  1. 伪数组是对象
  2. 伪数组原型是Object,而不是Array
  3. 所以伪数组没有数组的方法,如push()、shift()、find()等等
  4. 伪数组的属性名与数组的下标相似,以0,1,2,… 等的数字表示,也拥有length属性
  1. 数组的方法对象能用的上吗?==> 因为数组的大部分方法是要遍历数组,进行处理再创建一个新数组放回的,而数组项的调用 arr[i] 这种形式对象也能用,所以伪数组这个对象能适应部分数组方法
  2. 伪数组是对象,那怎么利用数组的方法呢?==> 可以使用 [].数组方法.call(伪数组, 参数...)[].数组方法.apply(伪数组, 参数) 来调用
  3. 所以利用伪数组与数组的相似点(属性与下标相似,拥有length属性,都可以用 [ ] 调用),可以很容易的利用数组的方法将伪数组变为真数组。
// 下面我尝试使用了数组中所以可能的方法,得出下列能将伪数组变为数组的方法
// 函数中的 arguments 是存储函数参数列表和特殊方法的对象,它是一个伪数组,我们将以它为例进行尝试
// 在实际应用中,如果伪数组为可迭代对象,直接运用前两种最简单的方法就够了

function fun1(v1, v2, v3) {
	console.log('-----------------arguments-------------------')
	console.log(arguments) // Arguments { 0: 1, 1: 2, 2: 3, … }
	console.log(Array.isArray(arguments)) // false
	console.log('------------------------------------')
	
	let x = null  // 定义变量x,接收伪数组转化后的结果
	
	// 简单方法(伪数组为可迭代对象)
	x = [...arguments]
	
	x = Array.from(arguments)
	
	
	// 调用数组方法
	x = [].filter.call(arguments, v => true)
	
	x = [].map.call(arguments, v => v)
	
	x = [].slice.call(arguments)


	// 上面各个方法调用后,成功将伪数组转为真数组,其返回的真数组都是一样的,如下
	console.log(x) // Array(3) [ 1, 2, 3 ]
	console.log(Array.isArray(x)) // true
} 

fun1(1, 2, 3)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值