伪类数组(Arguments)转真数组的常用三种方式

本文解释了JavaScript中伪数组arguments的特性,它是动态参数的容器,看似数组但实际上是对象。并介绍了将arguments转换为真数组的三种常见方法:[].slice.call(),Array.from(),和[...]运算符的使用示例。
摘要由CSDN通过智能技术生成

1.什么是伪数组?

我的理解是看上去像数组,其实他真正的数据类型是obj;

arguments还是一组实参的集合,当调用函数,不确定要放多少实参时,我们就可以用到。如下代码,我们可以放任意多的形参

 <script>
    function aa(){
        console.log(arguments);
    }
    aa(1,2,"8","ni")
    </script>

输出结果如下图,看上去是数组,其实是个对象,这就是伪数组

2. 如何将伪数组转真数组?

下面有三种常用方式

1)[ ].slice.call(arguments)
<script>
    function aa(){
        console.log(arguments);
        let a=[].slice.call(arguments)
        console.log(a);
       

    }
    aa(1,2,"8","ni")
    </script>
2) array.from(arguments)
<script>
    function aa(){
        console.log(arguments);
        let b=Array.from(arguments)
        console.log(b);
    }
    aa(1,2,"8","ni")
    </script>
3) [...arguments]
    <script>
    function aa(){
        console.log(arguments);
        let c=[...arguments]
        console.log(c);

    }
    aa(1,2,"8","ni")
    </script>

三种方式都能得到以下结果

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值