JS 调用函数时带括号与不带括号的差异

本文介绍了JavaScript中函数调用时带括号和不带括号的区别。带括号表示执行函数,不带括号则是赋值函数引用。举例说明了`a=text`和`b=text()`在console.dir下的不同输出,解释了何时使用括号以及不使用括号的情况,如window.onload=text。理解这一差异对于正确调用和使用函数至关重要。
摘要由CSDN通过智能技术生成

JS 调用函数时带括号与不带括号的差异

看下面一段函数代码:

        function text() {
            return '666'
        }
        var a = text;
        var b = text();
        console.dir(a);
        console.dir(b);
什么是函数:

​ 上述代码中,显然text()是函数。函数是一种叫做function引用类型的实例,因此函数是一个对象。而对象是保存在内存中的,函数名则是指向这个对象的指针。

带不带括号赋值的差异:

a表示把函数名text这个指针拷贝一份给变量a,但是这不是指函数本身被复制了一份。它只是传递了函数体所在的地址位置,在需要的时候好找到函数体去执行。

b表示立即执行text这个函数,b的值为函数的return值

在这里插入图片描述

​ 看上图就可以很明显的看出差异。变量a打印出来的是函数对象,而b打印出来的是返回的值666。

什么时候用括号,什么时候不用括号呢?

​ 函数只要是要调用它进行执行的,都必须加括号。此时,函数实际上等于函数的返回值或者执行效果,当然,有些没有返回值,但已经执行了函数体内的行为,就是说,加括号的,就代表将会执行函数体代码。

​ 不加括号的,都是把函数名称作为函数的指针,一个函数的名称就是这个函数的指针,此时不是得到函数的结果,因为不会运行函数体代码。它只是传递了函数体所在的地址位置,在需要的时候好找到函数体去执行。

function text() {
	xxxxxxx
}
window.onload = text;

​ 比如上述这段代码,text函数并不会在JS读到这段代码的时候就立即执行,浏览器加载文档的时候这句话会被加载,会被告知文档加载完要执行哪个函数,但实际上没有当时就执行,等到整个文档加载完成之后才会通过text这个指针去执行text()
​ 所以一般时候我们都是采用的是无括号的原因。因为括号是“函数调用运算符”,相当于在执行这样一个函数。

  • 12
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值