js作用域 函数调用

function A(){
    var a=1;
    var d=2;
    B(d);

}
function B(d){
    console.log(a);
}
A() //Error a is undefined

对js函数执行的作用域一直有点不明白
想问一下,像上面的代码,因为在函数A内部调用B函数,那整个作用域链不是应该是B-A-window嘛?那我如果是找a,在作用域链最顶端(即B)找不到a之后,为啥不在A中找,好像直接就在全局环境中了是吗?
麻烦能告知除了传a参数进去还有什么别的解决办法,谢谢啦~~

阅读 3.4k
5 个回答

js的作用域是词法作用域无论函数在哪里被调用,也无论它如何被调用,它的词法作用域都只由函数被声明时所处的位置决定。
如果把B定义在A里面,B就可以读到a了。

不是看调用的情况,是看如何定义的。
如果你在函数A中定义函数B,B的作用域链就是B-A-window

块级作用域之中,函数声明语句的行为类似于let,在块级作用域之外不可引用。在函数A中定义函数B就好了。有关作用域的问题可以看看这个作用域

这个是规范。
你的例子中a无论如何在B中是访问不到的,而

function B(d){ // 这个d是本地名义变量,一个参数名,和A定义中的d没有任何关系
    console.log("a");
}
function A(){
    var a=1;
    var d=2;
    B(d);// 这里用的值传递的方式让B内部的局部变量d有了A内局部变量d的值,但B仍然不能访问到A中的局部变量a。

}

你理解的在B中调用时的B-A-window这样的变量查询路径是想当然的,其实对B来说只有B-window,入口传的参数是另外一回事,和变量查询路径没有绝对关联。

函数作用域在函数定义的时候确定,B的定义在全局环境中,B的作用域是全局作用域。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题