JS中关于事件处理函数名后面是否带括号的问题


Posted in Javascript onNovember 16, 2016

今天总结一个关于事件处理程序的小细节。首先回顾一下事件处理的一些概念。

JS中的事件处理(事件绑定)就是让某种或某些事件触发某些活动。有两种常见的形式,分别是DOM Level 0 和DOM Level 2。这两种方式最大的区别就在于DOM 0级事件处理只能用于事件冒泡,而DOM 2级事件处理却可以通过设置第三个参数来分别支持事件冒泡和事件捕获。

DOM 0级事件处理一般是直接把一个函数分配给一个事件处理程序,既可以在元素中直接分配一个事件处理程序,如方式一所示;也可以在脚本中把函数分配给事件处理程序,如方式二所示。

<!--方式一-->
<div onclick="fun1();fun2('world!');"></div>
<!--方式二-->
<div id="a">点我</div>
<script>
var a=document.getElementById("a");
a.onclick=fun1; //方式二 
function fun1(){
alert("hello!");
}
function fun2(cc){
alert(cc);
}
</script>

这两种方式的区别在上述示例中也显示了,第一种方式可以同时绑定多个处理函数,但要注意必须是全局函数,否则会抛出Reference错误。第二种方式只能一次绑定一个处理函数,否则新的函数会覆盖旧的函数。

DOM 2级事件处理不会直接绑定处理函数,而是将函数添加为一个事件监听器如下,他也可以绑定多个处理函数,不会产生覆盖。但这种方式存在浏览器兼容的问题,IE下必须用attachEvent方法代替。

a.addEventListener("click",fun1,false); //事件冒泡
a.addEventListener("click",anotherFun,false); //不会覆盖上一事件,均被执行

简单回顾到这里,言归正传,不知道在回顾的过程中大家有没有注意到一个令人困惑的小细节,就是引用函数的时候,函数名称后面有的时候加括号,有的时候不加括号。这到底对程序的运行有怎样的影响呢?我经过查阅资料按照自己的理解小小的总结如下。

首先是加括号的,你可能经常在程序里面这样写“fun1();”,没错,函数名后边加括号表示立即执行该函数,如果函数内存在返回值则得到该值。这样用的多了,你可能就习惯在所有调用函数的地方这样写,比如之前说的事件处理函数。但是,如果你这样做了那就可能造成一些失控的状况。比如说,你明明只是想在点击某一元素的时候才执行函数,却发现这个函数在一开始就被执行了。你可以发现,上面举例时所用的DOM0方式二和DOM2级事件处理函数都没有在函数名后面加括号,原因就在于避免这种状况发生。如果你加了括号,这个函数fun1就会被立即触发执行。

那为什么DOM0方式一中却有括号呢?那是因为标签的事件属性里引号之间会被当做js语句直接执行,加了括号才能保证调用并执行函数。但是由于是用元素标签这种方式绑定的事件,执行的时机就被控制在了点击该标签时触发。

如果没有函数名又想立即执行呢?也就是立即执行匿名函数表达式,这种模式很常见,来观察一下它的屁股后面是不是也跟着个立即执行小括号呢?注意,这种IIFE形式中包裹着整个函数体的小括号会限制作用域。具体对IIFE感兴趣的童鞋可以去查阅相关资料,这里不作赘述。

(function(){
//do something...
})();

现在再来分析不加括号的,前面我们提到了不加括号可以避免失控。是因为只将函数名传递给事件,相当于将函数指针(也就是这个函数的入口地址)传给元素事件。这样做的好处就在于可以在需要的时候找到函数并执行。打个小比喻来说,你和你的朋友会面,加了小括号时你的朋友就立即出现在你面前,他才不管你当时是不是在忙,有种不请自来的不快感;而不加括号相当于你的朋友告诉了你他家在哪,当你需要他的时候就来找他,这可真是位贴心的朋友啦。所以,大多数事件绑定都仅仅只是传递给事件一个函数指针也就是函数名。

这时又有一个问题,之前说明的都是无参函数,如果是像代码示例中的fun2这种有参函数怎么办呢?难道只能用DOM0的方式一那种方法么?当然是否定的,尽量不要使用DOM0方式一那种形式,不符合结构与行为分离的原则。一般这种情况下就是使用匿名函数解决了,如下代码所示。如果大家有什么好的建议也可以留言分享一下~

//DOM Level 0
a.onclick=function(){
fun2("world!");
};
//DOM Level 2
a.addEventListener("click",function(){fun2("world!");},false);

以上就是我的总结,如有错误还要请大家多多指正,谢谢!感谢一起学习的小伙伴陈童鞋,正是因为他提的问题才让我注意到了这个经常被忽略的细节。

以上所述是小编给大家介绍的JS中关于事件处理函数名后面是否带括号的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js Date自定义函数 延迟脚本执行
Mar 10 Javascript
js实现图片轮换效果代码
Apr 16 Javascript
Javascript核心读书有感之语句
Feb 11 Javascript
jQuery双向列表选择器DIV模拟版
Nov 01 Javascript
prototype与__proto__区别详细介绍
Jan 09 Javascript
浅谈JavaScript中的apply/call/bind和this的使用
Feb 26 Javascript
SpringMVC+bootstrap table实例详解
Jun 02 Javascript
微信小程序之页面拦截器的示例代码
Sep 07 Javascript
VUE2.0 ElementUI2.0表格el-table自适应高度的实现方法
Nov 28 Javascript
Vue 实现html中根据类型显示内容
Oct 28 Javascript
关于vue2强制刷新,解决页面不会重新渲染的问题
Oct 29 Javascript
微信小程序实现Swiper轮播图效果
Nov 22 Javascript
微信小程序 时间格式化(util.formatTime(new Date))详解
Nov 16 #Javascript
jQuery实现的购物车物品数量加减功能代码
Nov 16 #Javascript
使用JavaScript获取URL中的参数(两种方法)
Nov 16 #Javascript
微信小程序 保留小数(toFixed)详细介绍
Nov 16 #Javascript
微信小程序 获取相册照片实例详解
Nov 16 #Javascript
js canvas仿支付宝芝麻信用分仪表盘
Nov 16 #Javascript
Javascript使用SWFUpload进行多文件上传
Nov 16 #Javascript
You might like
最简单的PHP程序--记数器
2006/10/09 PHP
PHP通过COM使用ADODB的简单例子
2006/12/31 PHP
php 注册时输入信息验证器的实现详解
2013/07/05 PHP
php探针使用原理和技巧讲解
2019/09/17 PHP
JQuery表格内容过滤的实现方法
2013/07/05 Javascript
JS实现图片翻书效果示例代码
2013/09/09 Javascript
JS+CSS 制作的超级简单的下拉菜单附图
2013/11/22 Javascript
解决JS中乘法的浮点错误的方法
2014/01/03 Javascript
javascript数组排序汇总
2015/07/07 Javascript
前端jquery部分很精彩
2016/05/03 Javascript
js获取鼠标点击的对象,点击另一个按钮删除该对象的实现代码
2016/05/13 Javascript
Node.js + Redis Sorted Set实现任务队列
2016/09/19 Javascript
jQuery Validate设置onkeyup验证的实例代码
2016/12/09 Javascript
react router4+redux实现路由权限控制的方法
2018/05/03 Javascript
vue数组对象排序的实现代码
2018/06/20 Javascript
在微信小程序中使用vant的方法
2019/06/07 Javascript
Vue formData实现图片上传
2019/08/20 Javascript
js实现简单的轮播图效果
2020/12/13 Javascript
[04:29]DOTA2亚洲邀请赛小组赛第一日 TOP10精彩集锦
2015/02/01 DOTA
Python面向对象之继承和多态用法分析
2019/06/08 Python
python中pytest收集用例规则与运行指定用例详解
2019/06/27 Python
Django处理Ajax发送的Get请求代码详解
2019/07/29 Python
pytorch 共享参数的示例
2019/08/17 Python
使用phonegap检测网络状态的方法
2017/03/30 HTML / CSS
用HTML5制作数字时钟的教程
2015/05/11 HTML / CSS
Html5 web本地存储实例详解
2016/07/28 HTML / CSS
Html5获取高德地图定位天气的方法
2019/12/26 HTML / CSS
美国演唱会订票网站:Ticketmaster美国
2017/10/05 全球购物
优秀大学生的自我评价
2014/01/16 职场文书
见习报告怎么写
2014/10/31 职场文书
上班迟到检讨书范文300字
2014/11/02 职场文书
个人欠款协议书范本2014
2014/11/02 职场文书
中秋客户感谢信
2015/01/22 职场文书
虎兄虎弟观后感
2015/06/12 职场文书
一些让Python代码简洁的实用技巧总结
2021/08/23 Python
HTML实现仿Windows桌面主题特效的实现
2022/06/28 HTML / CSS