猿来是你三十而立,砥砺前行,不忘初心,勇闯猿类

javascript 函数后面有多个小括号f( )( )( )...


有时我们看见js函数后面跟着多个小括号是什么意思?f( )( )( )...

f()执行f函数,返回子函数

f()()执行子函数,返回孙函数

f()()()执行孙函数,返回重孙函数

... ...

但注意,如果想这样执行,函数结构必须是这样,f的函数体里要return 子函数,子函数里要return 孙函数,如果没有return关键字,是不能这样连续执行的,会报错的。

举个例子:k是f的子函数,return子函数k,所以f()()能连续执行。

    var i=1;
    function f(){
        i++;
        console.log("打印 :  "+i)
        return k;
        function k() {
            return "I love you!"
        }
    }
    f();
    console.log("111111111111")
    f()()
    alert(f()());

结果如图:  

 

 

JavaScript 函数调用时带括号和不带括号的区别!!!
例子说明: 
例1.
function init(){
    。。。。。。
}
window.onload = init;
 
 
例2:
function fun(){
    return 5
}
var a=fun
var b=fun()
a是fun函数,b是5
 
 
那么到底在使用一个函数时需不需要加上()呢?
函数只要是要调用它进行执行的,都必须加括号。此时,函数实际上等于函数的返回值或者执行效果,当然,有些没有返回值,但已经执行了函数体内的行为,就是说,加括号的,就代表将会执行函数体代码。
不加括号的,都是把函数名称作为函数的指针,一个函数的名称就是这个函数的指针,此时不是得到函数的结果,因为不会运行函数体代码。它只是传递了函数体所在的地址位置,在需要的时候好找到函数体去执行。
 
例如window.onload=init;
init函数并不会在这行代码时就执行,浏览器加载文档时这句话会被加载,会被告知文档加载完要执行哪个函数,但实际上没有当时就执行,等到整个文档加载完成之后才会通过init这个指针去执行init()。
 
 
所以一般时候我们都是采用的是无括号的原因。这也是由于括号的二义性,因为括号是“函数调用运算符”,相当于在执行这样一个函数,所以产生的问题在理解了之后也就理解了。

  

posted @ 2019-02-15 11:17  青瑟少年  阅读(2810)  评论(0编辑  收藏  举报