首页 > js两个声明函数,相互调用是怎样进行的?

js两个声明函数,相互调用是怎样进行的?

function a(){ console.log(2)};
function b(){a();}
b();//2
function b(){a();}
function a(){ console.log(2)};
b();//2

结果与两个函数声明的顺序无关,想问一下:
声明函数a,b都会被提升,那么两者提升后在作用域中是怎么放置的?b函数执行时,代码执行细节是怎样的? 谢谢!


上面的代码你确认执行没有问题么?
按你上麦你的代码,根本无法执行的
应该是这样的吧

function a(){ console.log(2)};
function b(){a();};
b();//2
function a(){ console.log(2)};
function b(){a();};
b();//2

不要把声明和执行2个阶段混在一起看~~~
函数声明阶段,只确定函数中变量的作用域及语法问题,语句是否能执行是执行阶段要干的活~~~


这段代码其实“未涉及”提升...
js引擎在执行的时候,在作用域对b进行RHS查找,作用域给一个函数,执行,再对a进行RHS查找...
换句话说在你执行b之前声明都已经存在了。


这才能体现声明提升

b();
function a(){ console.log('a');console.log(2)};
function b(){ console.log('b');a();}

函数提升使声明的函数被提升到环境顶端
这种所谓的提升是建立在执行代码之前会先读取函数声明上面
而不是具体的谁在前谁在后
所以被调用的函数之前函数已经被提升

【热门文章】
【热门文章】