es6 函数参数作用域

函数的参数会形成一个单独的作用域

//因为函数参数形成一个单独作用域,所以foo的参数x和匿名函数中的x是处于同一个作用域中。foo函数内部使用的x就是参数x,给x赋值为3,但是后边接着执行y(),修改x=2,所以最后输出2
var x = 1;
function foo(x, y = function() { x = 2; }) {
  x = 3;
  y();
  console.log(x);
}

foo(); // 2


//下面例子中有3个作用域的x,
var x = 1;  //全局
function foo1(x, y = function() { x = 2; }) {  //x是匿名函数的局部变量
  var x = 3;  //函数foo1的局部变量
  y();
  console.log(x);
}

foo1(); // 3



//本例子充分说明匿名函数内的x不能访问函数foo1函数内的局部变量x
var x = 1;
function foo1(x, y = function() { console.log(x); }) {
  var x = 3;
  y();
  console.log(x);
}

foo1(); // undefined 3


但是一定要注意,上面第三个例子中,在函数内部重复声明参数,如果换成let来声明是不对的。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值