标签:log 函数 console 返回值 span code 返回 ret 不清楚
js中的方法什么时候加括号什么时候不加括号呢,我们有时候经常就搞不清楚,记住下面这几点就好理解了。
1.函数做参数时都不要加括号。
function fun(a){ alert(a); } function getE(fun,e){ fun(e); } getE(fun,3);//弹出3,这里把函数fun当成实参传入,所以就不用加括号了。
2.函数调用的时候是要加括号的,上面这个例子中getE这个函数调用的时候,不管有没有参数,都是要加括号的。
3.函数作为赋值符号右边的时候,无括号表示的是传递函数这个对象,有括号的时候表示传递的是函数的返回值。当作为retrun返回语句时也是同理。
function fun(){ console.log("666"); } //var getFun = fun();这样就直接打出666了。 var getFun = fun; getFun();//这样子就是表示对这个函数的引用,要执行的话就还要加括号去调用。
上面这个例子比较简单,我们看下面这个稍微复杂一点的。
function f1() { var n = 999; function f2() { alert(n); } return f2; } var result = f1();//这里是要执行f2这个函数,所以f1加括号,传递的是他的返回值,这里是f2。 result();//然后这里再加括号去掉用f2,所以结果弹出999。
那如果我们把f1的括号去掉,依旧要弹出n怎么办呢?我们可以这么做:
function f1() { var n = 999; function f2() { alert(n); } return f2();//所以要在这里加个括号,这样就会返回f2然后调用,就可以弹出n了。 } var result = f1;//这里我们把f1的括号去掉,那么就是对这个函数的引用 result();//然后这里就只是执行了f1这个函数。结果是返回f2,就不会弹出n
最后总结:我们只需要记住最后那一点就可以了:无括号表示的是传递函数这个对象,有括号的时候表示传递的是函数的返回值。
标签:log 函数 console 返回值 span code 返回 ret 不清楚
原文地址:http://www.cnblogs.com/wangxi01/p/6428004.html