事件是 Web 应用中不可或缺的一个东西,用户在应用中执行一个操作的时候,比如鼠标单击时要触发执行一些事情,就可以给该事件绑定一个事件处理程序(event handler)。使用 jQuery 的 .on() 方法可以为选中的元素绑定任意的 DOM 事件,并添加事件处理程序。假设有如下 HTML 结构:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> </head> <body> <button id="example" type="button">Click me!</button> <script src="http://code.jquery.com/jquery-1.11.2.js"></script> <script> // code here </script> </body> </html>
在 <script> 元素内添加如下代码,其中,事件名称是 .on() 方法的第一个参数,事件处理程序的回调函数作为第二个参数:
$('#example').on('click', function(e) {
alert('Clicked!');
});
这样当该按钮元素触发鼠标单击(click)事件的时候就会执行绑定的事件处理程序,弹出一个对话框!回调函数的第一个参数 e 为事件对象,通过该对象可以得到很多事件相关的信息,比如事件类型,事件发生的坐标点等以及一些事件方法。回调函数除了可以像这样使用一个匿名函数,也可以使用一个变量标识的函数引用:
$('#example').on('click', clickHandler);
同时绑定多个事件
另外,jQuery 还支持使用空格分隔多个事件名称来同时绑定多个事件,比如 mouseenter mouseleave,同时给元素绑定鼠标移入和鼠标移出事件。可以通过事件对象的 type 属性来判断发生的是哪个事件:
$('#example').on('mouseenter mouseleave', function(e) {
if (e.type === 'mouseenter') {
// mouseenter
} else {
// mouseleave
}
});
除了上面这种方法外,还可以传入一个键值对来绑定多个事件:
$('#example').on({
mouseleave: function() {
// mouseleave
},
mouseenter: function() {
// mouseenter
}
});
事件上下文
同时给多个元素绑定事件处理程序的时候可以使用事件执行的上下文来简化代码:
$('li').on('click', function() {
var $this = $(this);
$this.addClass('active');
});
上下文关键字 this 引用的是原生 DOM 元素,所以如果要使用 jQuery 的方法需要先包装成 jQuery 对象。
事件委托
事件会经过一个捕捉和冒泡的过程,为了兼容,jQuery 只使用了事件的冒泡,即目标元素触发事件后会逐级冒泡直到顶级元素节点。利用事件的冒泡可以将目标元素的事件处理程序绑定到其祖先元素上统一处理,可以给 .on() 方法传入一个可选的选择器字符串作为第二个参数:
$(document).on('click', '#example', clickHandler);
此时表示将 id="example" 的元素的鼠标单击事件委托绑定到了 document 元素上,当目标元素(即 id="example" 的元素)触发鼠标单击事件的时候,该事件就会冒泡到 document 元素上,从而触发事件处理程序。使用事件委托的好处是如果页面上有很多列表,每个列表都去绑定一个鼠标单击事件,那么就会有很多事件处理程序,会对性能造成影响。利用事件冒泡的原则,将事件处理程序绑定到目标元素的父元素或者祖先元素上,可以明显地减少事件处理程序的数量,改善性能:
$('ul').on('click', 'li', clickHandler);
使用事件委托另外一个好处是那些动态添加的 <li> 元素也会具有事件处理程序。个人比较侵向于将事件都委托到 document 元素上方便管理,而且也不用等到 DOM 准备就绪:
$(document)
.on('click', 'selector-1', clickHandler)
.on('focusin', 'selector-2', focusHandler);
在 IE8 中一些事件比如 submit 或者 change 是不会冒泡的,但是 jQuery 对此做了处理,因此也可以放心使用。像 focus 和 blur 事件则推荐使用相应的 focusin 和 focusout 事件来代替。对于 mouseover 和 mouseout 事件,为了避免事件冒泡造成的不良影响,推荐使用 mouseenter 和 mouseleave 来代替。
阻止事件冒泡与默认行为
调用事件对象的 .stopPropagation() 方法可以阻止事件冒泡:
$('#example').on('click', function(e) {
e.stopPropagation();
});
这样当单击事件在该元素上发生的时候就不会冒泡了。jQuery 还有另外一个方法 .stopImmediatePropagation() 调用后事件冒泡被阻止同时该元素上后面绑定的事件处理程序也不会执行了:
$('#example').on('click', function() {
alert('Clicked-1!'); // 会执行
}).on('click', function(e) {
e.stopImmediatePropagation();
}).on('click', function() {
alert('Clicked-2!'); // 不会执行
});
调用事件对象的 .preventDefault() 方法可以阻止事件的默认行为:
$('#example').on('click', function(e) {
e.preventDefault();
});
在事件处理程序中直接返回 false 可以同时取消冒泡和阻止默认行为:
$('#example').on('click', function() {
return false;
});
相当于同时调用了事件对象上面的 .stopPropagation() 和 .preventDefault() 方法。如果没有其它操作,还可以进一步简写为 $('#example').on('click', false);。
应用示例,点击按钮显示弹出层,点击文档其它地方隐藏:
$(document)
.on('click', '#example', popup.show)
.on('click', popup.hide);
由于事件冒泡,所以该弹出层并不会显示出来,需要在事件处理程序中阻止事件冒泡:
$(document)
.on('click', '#example', function(e) {
e.stopPropagation();
popup.show();
}).on('click', popup.hide);
获取原生事件对象
事件处理程序中引用的事件对象实际上是经过 jQuery 包装过的,有时候需要使用浏览器原生的事件对象,要得到浏览器原生的事件对象可以通过事件对象的 originalEvent 属性获取。例如,使用拖拽事件的时候就会用到原生的事件对象:
$('#example').on('dragstart', function(e) {
var originalEvent = e.originalEvent;
originalEvent.dataTransfer.effectAllowed = 'move';
originalEvent.dataTransfer.setData('text/plain', $(this).text());
originalEvent.dataTransfer.setData('text/html', $(this).html());
originalEvent.dataTransfer.setDragImage('/images/drag.png', -10, -10);
});
传递数据
可以给事件处理程序传入数据,该数据保存在事件对象的 data 属性中:
$('#example').on('click', 1, function(e) {
console.log(e.data); // 1
});
为了区别事件代理,传递的数据貌似不能是一个直接的字符串,不过可以传入一个对象来代替:
$('#example').on('click', {str: 'xxx'}, function(e) {
console.log(e.data.str); // xxx
});
自定义事件
除了浏览器的标准事件,还可以绑定自定义事件的事件处理程序,其中事件名可以使用任意命名:
$('#example').on('sleep', function() {
alert('Sleeping!');
});
标准事件的事件处理程序可以通过浏览器原生事件去触发,而自定义事件的事件处理程序则可以使用 jQuery 的 .trigger() 方法触发,使用方式如下,传入需要触发的事件名称作为参数:
$('#example').trigger('sleep');
可以通过给 trigger() 方法传入更多参数来给事件处理程序传递数据,数据会作为回调函数的参数进行传递:
$('#example').on('sleep', function(e, time) {
alert('Sleep at' + time);
});
$('#example').trigger('sleep', '22:00');
应用示例,使用自定义事件编写异步代码:
$('#example').on('done', doHandler);
function foo() {
setTimeout(function() {
// foo 函数的逻辑比较耗时,所以使用 setTimeout 函数排队
$('#example').trigger('done'); // 执行完了,通知一声
}, 1000);
}
foo 函数执行完成后,就会触发元素的 done 事件,前面绑定的 doHandler 函数就会开始执行。
事件命名空间
无论是浏览器标准事件或是自定义事件都可以添加命名空间,添加在事件名称后面,通过一个 . 号分隔,像这样 click.widget,也可以给一个事件添加多个命名空间 click.widget.common,使用命名空间可以更有针对性地触发或者移除某个特定的事件处理程序。比如一个元素同时绑定了 click.tab 和 click.collapse 两个点击事件,当使用 .trigger() 方法触发 click.collapse 事件时会执行该事件的事件处理程序,而 click.tab 的事件处理程序则不会执行。
移除绑定事件
使用 .off() 方法可以移除绑定的事件处理程序,有下面几种情况:
一次*件
使用 .one() 方法绑定的事件处理程序只会触发执行一次,一次后自动移除:
$('#example').one('click', clickHandler);
事件节流
浏览器中有几个事件会频繁触发,比如 scroll, resize, mousemove 等,那么给这些事件绑定的事件处理程序也会跟着频繁地执行,导致页面反应迟钝,要解决这个问题,需要节流事件,减少事件处理程序执行的频率:
var timer = 0; // 使用一个定时器
$(window).on('scroll', function() {
if (!timer) {
timer = setTimeout(function() {
// Do something
timer = 0;
}, 200);
}
});
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# jQuery
# 事件
# jquery事件绑定方法介绍
# jQuery中的常用事件介绍
# jQuery的事件处理你知道多少
# JQuery绑定事件四种实现方法解析
# jQuery操作事件完整实例分析
# jQuery事件_动力节点Java学院整理
# jquery事件与绑定事件
# jquery中绑定事件的异同
# jQuery事件详解
# jQuery中的事件详解
# 绑定
# 移除
# 鼠标
# 就会
# 多个
# 单击
# 自定义
# 可以通过
# 还可以
# 回调
# 弹出
# 可以使用
# 的是
# 也会
# 第一个
# 推荐使用
# 第二个
# 另外一个
# 来代替
# 是一个
相关文章:
建站之星代理如何获取技术支持?
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
如何用景安虚拟主机手机版绑定域名建站?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
安云自助建站系统如何快速提升SEO排名?
如何高效完成自助建站业务培训?
建站之星如何实现网站加密操作?
建站之星备案流程有哪些注意事项?
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
建站为何优先选择香港服务器?
制作网站怎么制作,*游戏网站怎么搭建?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
如何获取开源自助建站系统免费下载链接?
如何通过虚拟主机快速完成网站搭建?
宁波免费建站如何选择可靠模板与平台?
如何在腾讯云免费申请建站?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
如何在企业微信快速生成手机电脑官网?
高端建站三要素:定制模板、企业官网与响应式设计优化
如何快速搭建高效香港服务器网站?
如何在Golang中指定模块版本_使用go.mod控制版本号
如何通过NAT技术实现内网高效建站?
深圳网站制作的公司有哪些,dido官方网站?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
建站之星客服服务时间及联系方式如何?
外贸公司网站制作哪家好,maersk船公司官网?
,怎么在广州志愿者网站注册?
购物网站制作公司有哪些,哪个购物网站比较好?
建站之星如何取消后台验证码生成?
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
如何配置支付宝与微信支付功能?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
高防服务器租用如何选择配置与防御等级?
seo网站制作优化,网站SEO优化步骤有哪些?
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
建站之星价格显示格式升级,你的预算足够吗?
山东网站制作公司有哪些,山东大源集团官网?
如何选择PHP开源工具快速搭建网站?
制作网站外包平台,自动化接单网站有哪些?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
宝塔新建站点报错如何解决?
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
如何在服务器上三步完成建站并提升流量?
如何在云服务器上快速搭建个人网站?
学校建站服务器如何选型才能满足性能需求?
大同网页,大同瑞慈医院官网?
c# await 一个已经完成的Task会发生什么
建站主机功能解析:服务器选择与快速搭建指南
*请认真填写需求信息,我们会在24小时内与您取得联系。