JavaScript、jQuery函数调用时加括号()和不加括号的区别。 调用函数时何时选择加括号(),何时选择不加括号?ide
今天学习jQuery拿一个功能作练习时,由于存在重复的代码,因此写了一个复用的函数提供调用
可是在调用函数的时候却没有起任何做用,通过检查发现问题出如今调用函数时加了括号致使的
那么在调用函数时,加括号和不加括号有什么区别呢?因而经过搜索理解后获得了如下的结论:函数
function bracket() { return 0; } // 函数后加括号 var a = bracket(); console.log(a); // 输出0 // 函数后不加括号 var b = bracket; console.log(b); // 输出[Function: test]
其中"bracket"函数名是一个对象,而对象是保存在内存中,函数名是指向这个对象的指针。学习
var a = bracket() 函数后面加上括号就表示当即调用
var b = bracket 就是把"bracket"这个函数对象的指针指向b指针
函数只要是调用它进行执行的,都必须加括号。此时,函数实际上等于函数的返回值或者执行效果,固然有些没有返回值,但已经执行了函数体内的行为。就是说:加括号的就表明将会执行函数体代码。对象
不加括号的:都是把函数名称做为函数的指针,一个函数的名称就是这个函数的指针,此时不是获得函数的结果,所以不会执行函数体代码。它只是传递了函数体所在的地址位置,在须要的时候好找到函数体去执行。ip
函数带括号,会直接执行函数代码体的内容。内存
函数不带括号,则至关于一个指针,会指向函数,可是不执行函数体代码内容,当符合函数执行条件的时候,再执行函数体代码。it