关于JS中的方法是否加括号的问题

Posted 来亦何哀

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于JS中的方法是否加括号的问题相关的知识,希望对你有一定的参考价值。

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

最后总结:我们只需要记住最后那一点就可以了:无括号表示的是传递函数这个对象,有括号的时候表示传递的是函数的返回值。

 

以上是关于关于JS中的方法是否加括号的问题的主要内容,如果未能解决你的问题,请参考以下文章

关于js----------------分享前端开发常用代码片段

如何理解这段代码片段中的两对括号?

几个关于js数组方法reduce的经典片段

几个关于js数组方法reduce的经典片段

js中调用函数时加不加括号的问题

js调用函数时加括号与不加括号的区别