es6 中函数参数独立作用域

如果参数是一个函数那么,这个函数有外层环境吗?还是说函数里能访问的变量只能是在这个作用域中声明的?
例如:
var x = 1;
function foo1(x, y = function() { console.log(x); }) {
var x = 3;
y();
}

foo1();


上面中作为参数的匿名函数,有外层作用域吗?

2个回答

es6中函数内有两层作用域,外层是创建函数参数的作用域(可以在这个作用域中设置参数的默认值)。内层是函数体的作用域,如果块作用域不算,加上全局作用域,就是三个作用域。
就是说es6中函数的参数和函数体内用var声明的变量不在同一个作用域中,es5是不是也这样好像无法验证。
一个函数所处的作用域是函数创建时的作用域,不是调用时的作用域。

你的 y = function() { console.log(x);}是在创建函数参数的作用域中的,这里的x访问的是函数的参数x,参数x没有被赋值就是undefined,
注意:参数x和函数体内用var x=3声明的变量不在同一个作用域中,不是同一个变量。
如果你foo1函数没有参数x,就会在外层作用域(也就是全局作用域)中寻找x变量。

用下面例子会好理解一些

var x = 1;
function foo1(x=2, y = function() { console.log(x); }) {//输出2
var x = 3;
console.log(x);//输出3
y();
}
foo1();
console.log(x);//输出1
qq_44885374
小新大人y 希望大佬能考虑一下我的看法 心里对这块也是很疑惑 求答复
5 个月之前 回复
qq_44885374
小新大人y 就是说es6中函数的参数和函数体内用var声明的变量不在同一个作用域中。我觉得这句话有问题!如果不在同一个作用域,在函数体内部就可以使用let再次声明变量。但是实际上函数体内部不能使用let再次声明变量,会报错!!!而es6官网给的解释是:let不允许在相同作用域内,重复声明同一个变量。function func(arg) { let arg; } func() // 报错 赞成有两个作用域,但是函数参数作用域,在函数初始化结束,这个作用域就会消失。
5 个月之前 回复
u013182438
xingyemeng1202 明白了,谢谢
大约 2 年之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 正解!
大约 2 年之前 回复

foo1里面的函数的作用域在foo1里面

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问