前端面试 JavaScript— 函数的arguments为什么不是数组?如何转化成数组?

Posted aiguangyuan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端面试 JavaScript— 函数的arguments为什么不是数组?如何转化成数组?相关的知识,希望对你有一定的参考价值。

因为arguments本身并不能调用数组方法,它是一个另外一种对象类型,只不过属性从0开始排,依次为0,1,2...最后还有 callee 和length属性,我们也把这样的对象称为类数组。

常见的类数组还有:

1. 用getElementsByTagName/ClassName()获得的htmlCollection;

2. 用querySelector获得的nodeList。

那这导致很多数组的方法就不能用了,必要时需要我们将它们转换成数组,有哪些方法呢?

Array.prototype.slice.call()

function sum(a, b) 
    // 将类数组转换为数组
    let args = Array.prototype.slice.call(arguments);
    // 对转换为数组的方法调用累加
    let num = args.reduce((sum,cur) =>
        return sum+cur;
    )
    console.log(num);
;
sum(1,2,3,4,5,6);
// 21

Array.from()

function sum(a, b) 
    // 将类数组转换为数组
    let args=Array.from(arguments)
    // 对转换为数组的方法调用累加
    let num = args.reduce((sum,cur) =>
        return sum+cur;
    )
    console.log(num);
;
sum(1,2,3,4,5,6);
// 21

这种方法也可以用来转换Set和Map哦!

ES6展开运算符

function sum(a, b) 
    // 将类数组转换为数组
    let args= [...arguments];
    // 对转换为数组的方法调用累加
    let num = args.reduce((sum,cur) =>
        return sum+cur;
    )
    console.log(num);
;
sum(1,2,3,4,5,6);
// 21

利用concat+apply

function sum(a, b) 
    // 将类数组转换为数组
    // apply方法会把第二个参数展开
    let args=Array.prototype.concat.apply([], arguments);
    // 对转换为数组的方法调用累加
    let num = args.reduce((sum,cur) =>
        return sum+cur;
    )
    console.log(num);
;
sum(1,2,3,4,5,6);
// 21

当然,最原始的方法就是再创建一个数组,用for循环把类数组的每个属性值放在里面,过于简单,就不浪费篇幅了。

以上是关于前端面试 JavaScript— 函数的arguments为什么不是数组?如何转化成数组?的主要内容,如果未能解决你的问题,请参考以下文章

前端面试 JavaScript— 什么是闭包?

前端面试 JavaScript— 原型对象和构造函数有何关系?

前端面试 JavaScript— 原型对象和构造函数有何关系?

前端面试题 ---- 手撕JavaScript call apply bind 函数(超详细)

前端面试宝典 - Javascript 基础知识

JavaScript基础--------三座大山(前端面试必考)