关于ES6的默认参数对arguments的结果的影响

案列一
function f1(arr){
    arr[0]=arr[2];
}
function f2(a,b,c=3){
    b=2
    c=10;
    f1(arguments)
    console.log(arguments);
    console.log(a+b+c);
}
f2(1,1,1);
打印结果
Arguments(3) [1, 1, 1, callee: (...), Symbol(Symbol.iterator): ƒ]
13

案列二

function f1(arr){
    arr[0]=arr[2];
}
function f2(a,b,c){
    b=2
    c=10;
    f1(arguments)
    return a+b+c;
}
f2(1,1,1);

打印结果
Arguments(3) [10, 2, 10, callee: (...), Symbol(Symbol.iterator): ƒ]
22

这是为什么了?发到群里问了下 得到这样一个回复


这个图完美的解决了我的困惑,默认参数下  arguments永远只看调用时的参数 所以arguments永远是[1,1,1]
但是里面的a,b,c会随着函数内部的赋值有变化 a=1,b=2,c=10; 而括号内c=3 直接被覆盖
非剩余参数,默认参数,解构赋值的情况下 arguments和参数变化保持一致


arguments和里面的参数a,b,c不同步了

猜你喜欢

转载自blog.csdn.net/qq_28019937/article/details/82152946