JS中函数名后面的括号加与不加的区别和作用

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<body>
<button id="btn">按钮</button>
<script>
var e =document.getElementById("btn");
e.addEventListener("click",demo1)

function demo1(){
alert("hello1")
    }
e.addEventListener("click",demo2)
function demo2(){
alert("hello2")
    }
</script>
</body>
</html>

在上面的代码中,例如e.addEventListener("click",demo2)demo2后面加了括号变成打开页面直接弹出对话框而不用去点击按钮不加括号则是通过点击按钮才触发事件弹出对话框。

e.addEventListener("click",demo2())

 

只需要记住,函数名就是指针就可以了。例如
function fun(){
    return 5
}
var a=fun
var b=fun()

JS中函数是一种叫做function引用类型的实例,因此函数是一个对象。对象是保存在内存中的,函数名则是指向这个对象的指针。


var a = fun 表示把函数名fun这个指针拷贝一份给变量a, 但是这不是指函数本身被复制了一份。
就好比,地图上上海市(对应函数对象)只有一个,但指向上海市的路标(对应指针)有很多,而且你还可以继续添加(复制)无数个指向上海市的路标,但上海市本身不会被复制。


如果函数名后面加上圆括号就表示立即调用(执行)这个函数里面的代码(花括号部分的代码)。

另外函数声明和函数表达式在私有作用域写法方面也会在函数体后面加圆括号表示立即调用这个函数,题主可以参看JS的 模仿块级作用域的知识。


作者:闭家锁
链接:https://www.zhihu.com/question/31044040/answer/69898827

转载于:https://www.cnblogs.com/morongwendao/p/6531949.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值