关于javascript函数带不带括号的问题

学习javascript的时候一直对函数名的使用一直觉得不可思议。使用函数名的时候到底加不加括号我一直拿不准。今天在看javascript闭包的问题时遇到比较有意思的例题。现在总结一下,免得到时候又黄继光了。。。

function outerFn(){
  console.log("outer");
  function innerFn(){
    console.log("inner");
  }
  return innerFn;
}
console.log("-------------");

var func = outerFn;
func();

console.log("-------------");

var func2 = outerFn();
func2();

console.log("-------------");

然后输出结果是:

关于javascript函数带不带括号的问题_第1张图片

在函数外部定义变量func = outerFn;意思是func是outerFn函数的引用,执行的时候就是执行outerFn函数本身。

另一个变量func2 = outerFn();  赋值的是outerFn()函数执行的结果。即return返回来的内容。在这就是innerFn函数;

至于为什么调用innerFn还会执行innerFn之外的console.log("outer"),我还不太明白。。


如果函数没有return:

function test(){
  console.log("test");
}

var func = test;
func();

var func1 = test();
func1;
则带括号的函数返回的是undefined(这里的func1是undefined;);



你可能感兴趣的:(javascript)