jQuery使用(七):事件绑定与取消,及自定事件的实现原理
实例方法:
- on()
- one()
- off()
- trigger()
- hover()
一、绑定事件与jQuery事件委托
- $(selector).eventType(fn);
- $(selector).on(event,childSelector,data,function);
- $(selector).one(event,data,function);
1.jQuery可以直接通过点击内置事件类型方法来添加事件程序,比如添加点击事件:$("...").click(function(){console.log(“点我”);});
2.on()方法绑定事件处理程序:
| 参数 | 说明 |
| event |
必需。规定要从被选元素移除的一个或多个事件或命名空间。 由空格分隔多个事件值,也可以是数组。必须是有效的事件。 |
| childSelector | 可选。规定只能添加到指定的子元素上的事件处理程序(且不是选择器本身,比如已废弃的 delegate() 方法)。 |
| data | 可选。规定传递到函数的额外数据。 |
| function | 可选。规定当事件发生时运行的函数。 |
3.这里展示一下不常见的添加多个事件程序:
//html
<p>Move.</p> //css
.intro{
font-size:150%;
color:red;
} //js--toggleClass()方法对添加和移除被选元素的一个或多个类进行切换。
$("p").on("mouseover mouseout",function(){
$("p").toggleClass("intro");
});
4.当然也可以给同一个事件绑定多次,与addEventListener()的元素js方法一致。
5.当不指定给子元素绑定事件时,有需要给事件函数传入更多数据的话可以采用对象的方式传入,这样第二个参数就不会被识别为选择器了。(更简单的方式就是直接给第二个参数写一个逗号,不传入参数)
6.jQuery事件委托:
//html
<ul>
<li>0</li>
...省略n个li
<li>n+1</li>
</ul> //js
$("ul").on("click",function(e){
alert( $(e.target).text() );
});
但是在事件委托有时候会存在一些问题,以上面示例来说,比如不希望点击事件在ul上触发,那么这时候第二个参数就发挥作用了:
$("ul").on("click","li",function(e){
alert( $(e.target).text() );
});
通过以上的修改后,依旧保持事件委托状态,但是点击ul时,事件不会执行,而点击li依然可以正常执行。
7.关于一次事件(one())绑定的应用:
- 有需求是第一次点击a标签跳转淘宝,以后点击都跳转百度
//html
<a href="https://www.baidu.com" target="_blank">jump</a> //js
$("a").one("click",function(e){
window.open("https://www.taobao.com");
//阻止第一次点击跳转到百度(下面两个操作都可以实现)
//return false;
e.preventDefault(); });
8.同时给一个dom添加多个事件程序
//html
<div class="demo" style="width: 100px;height: 100px;background-color: red;"></div> //js
$(".demo").on({
click:function(){
console.log('click');
},
mouseenter:function(){
console.log('mouseenter');
},
mouseleave:function(){
console.log('mouseleave');
}
});
二、解除事件程序
- jQuery.off()
- jQuery.off(eventType)
- jQuery.off(eventType,fun)
- jQuery.off(eventType,daughter,fun)
//html
<div class="demo" style="width: 100px;height: 100px;background-color: red;"></div> //js
function eventOne(){ console.log("eventOne"); }
function eventTwo(){ console.log("eventTwo"); } $(".demo").on('click',eventOne);
$(".demo").on('click',eventTwo);
$(".demo").on('mouseenter',eventOne); $(".demo").off();//解除demo所有事件的事件程序,包括默认事件
$(".demo").off("click");//解除demo的点击事件的所有事件程序
$(".demo").off("click",eventOne);//解除demo的点击事件的eventOne事件程序
在事件委托的事件处理程序绑定时,有指定事件程序只在后辈元素上才有效执行,在绑定事件的元素上不会被触发的一种绑定方式,看示例:
//html
<ul>
<li>0</li>
...省略n个li
<li>n+1</li>
</ul> //js
$("ul").on("click","li",function(e){
alert( $(e.target).text() );
});
这种绑定方式实质上就是将事件绑定在ul上,所以解绑事件程序还是解绑ul的事件程序:
$("ul").off("click");
$("ul").off("click","li");//这种方式也没问题
$("ul").off("click","li",fun);//为了程序的可读性,怎么绑定就怎么解除是最规范的写法
当然上面的事件程序是函数表达式不能指定实现指定函数解绑了。
三、主动触发事件程序方法(trigger)及实现原理
- $(selector).trigger(event,param1,param2,...)
- 使用说明:
| 参数 | 说明 |
| event | 必需。规定指定元素上要触发的事件。可以是自定义事件,或者任何标准事件。 |
| param1,param2,... |
可选。传递到事件处理程序的额外参数。额外的参数对自定义事件特别有用。 也可以写成数组方式传入[param1,param2,...] |
一个简单的trigger示例代码:
//html
<div class="demo" style="width:100px; height:100px; background-color:red;"></div> //js
$(".demo").on("click", function(a,b,c,d){
console.log(a,b,c,d);
});
$(".demo").trigger("click",[10,20,30,40]);
常见的trigger()使用场景“首次加载倒数广告图层”,当倒数到零时自动取消广告图层,也可以在没有到达零秒之前人为点击取消广告。
(时间紧迫,本想封装一个完整的功能的,有时间再来实现了!)
jQuery.on()的自定义事件
trigger与自定义事件实现原理
把on的自定义事件放到这部分来分析,绝对不是前面忘记了,想必聪明的你已经想到了,自定义方法没有触发机制,所以必须要trigger()方法来帮助自定义事件触发事件程序。先来看一个简单的自定义事件示例:
//定义自定义事件pageLoad
$(".demo").on("pageLoad",function(){
console.log("我的第一个jQuery自定义事件");
});
//trigger触发pageLoad事件
$(".demo").trigger("pageLoad");
应用之简单是吧,好友没有撸源码了,来一波。
咳咳,我得纠正一下态度,绝不是因为它简单我就欺负它,而是大有用途,后期会基于jQuery模仿封装一个自己的fullPage插件,会大量的使用到自定义事件,所以觉得在这里有必要对jQuery自定义事件的原理及trigger的原理有深入的理解。(偷偷告诉你,自定义机制和触发事件机制在初级和中级前端面试中被提问的几率很高哦,中级和高级前端面试中常被提问的Event模块其内部思想非常类似)
//自写jQuery源码部分 //--on()--仅封装自定义事件(内部事件后期再补充)
//参数:type -- 事件类型; handle -- 事件触发程序
jQuery.prototype.myOn = function(type,handle){
//遍历jQuery对象的所有DOM
for(var i = 0; i < this.length; i++){
//给每个DOM上添加cacheEvent,用来保存每个DOM添加的事件类型
if( !this[i].cacheEvent ){
this[i].cacheEvent = {};
}
//每个DOM的每个事件类型(cacheEvent[type])上可以存储多个事件处理函数
if( !this[i].cacheEvent[type] ){
//第一次添加该事件类型时,直接将事件处理函数作为数组元素添加到该事件类型下
this[i].cacheEvent[type] = [handle];
}else{
//如果有该事件类型,并且有值,就将事件函数添加到数组后面
this[i].cacheEvent[type].push(handle);
}
}
} //--trigger事件触发
//参数:type -- 事件类型
jQuery.prototype.myTrigger = function(type){
var self = this;
//获取事件程序需要的参数 -- 兼容序列化和数组两种方式传入
var params = arguments.length > 1 ? (Object.prototype.toString.call(arguments[1]) == "[object Array]" ? arguments[1] : [].slice.call(arguments,1) ) : [];
//遍历jQuery对象的所有DOM
for(var i = 0; i < this.length; i++){
//判断是否含有指定的事件类型
if( this[i].cacheEvent[type] ){
//遍历并执行DOM上指定事件类型的所有函数 -- ele函数
//由于forEach内执行事件程序是this指向window,所以需要self
this[i].cacheEvent[type].forEach(function(ele,index){
ele.apply(self,params);
});
}
}
} //测试代码
<div class="demo" style="width: 100px; height: 100px; background-color: red;"></div> <script type="text/javascript" src="MyjQuery.js"></script>
<script type="text/javascript">
$(".demo").myOn("pageLoad",function(a,b,c){
console.log("trigger成功"+ a + b + c );
});
$(".demo").myTrigger("pageLoad",10,20,30);
$(".demo").myTrigger("pageLoad",["中","国","人"]);
</script>
全部jQuery源码等总结完jQuery使用系列博客后会在相关博客上传。
四、hover()
其实hover这个方法非常的简单,而且经常使用,这个方法同等于mouseenter和mouseleave,这种操作非常贴合交互行为,鼠标移入必然就会有移出,如果在这两个状态下需要对行为作出反应,这个方法就再合适不过了,下面就写一个同等对比示例代码:
$(".demo").on("mouseenter",function(){
consoel.log("enter");
}).on("mouseleave",function(){
consoel.log("leave");
});
//haver同等代码
$(".demo").hover(function(){
console.log("enter");
},function(){
console.log("leave");
});
但是hover并不是最友好的交互选择,因为连续的鼠标移入移出会出现抖动,因为事件被触发后会被放到执行队列,会把所有移入移出行为触发的事件都执行,所以对交互体验有一定要求的功能慎用。
jQuery使用(七):事件绑定与取消,及自定事件的实现原理的更多相关文章
- javascript 的事件绑定和取消事件
研究fabricjs中发现,它提供canvas.on('mousemove', hh) 来绑定事件, 提供 canvas.off()来取消绑定事件这样的接口,很是方便, 那我们就不妨探究一下内在的实现 ...
- 事件绑定、取消的二种形式 & call
<script> //call 函数下的一个方法,call方法第一个参数可以改变函数执行过程中的内部this的指向,call方法第二个参数开始就是原来函数的参数列表. function f ...
- 学习javaScript必知必会(4)~事件、事件绑定、取消事件冒泡、事件对象
1.常用的事件: ① onload:页面加载 ② onblur: 失去焦点 onfocus: 获取焦点 ③ onclick:点击 ④ onmouseover:鼠标经过 onmouseout:鼠标离开 ...
- 事件绑定的快捷方式 利on进行事件绑定的几种情况
[事件绑定快捷方式]$("button:first").click(function(){ alert(1); }); [使用on绑定事件] ① 使用on进行单事件绑定 $(&qu ...
- jQuery 中的事件绑定与取消绑定
1:在jQuery中使用bind方法进行事件的绑定,bind方法有两个参数,第一个参数是事件的类型例如click,change,keyup,keydown,blur,focus等.第二个参数是一个回调 ...
- jQuery事件绑定的最佳实践
如果你经常使用jQuery,那么你也许很熟悉事件绑定.这是很基本的东西,但是深入一点,你就能够找到机会让你事件驱动的代码变得不太零碎,并且更容易管理. 更好的选择器策略 让我们从基础的例子开始.下面的 ...
- jQuery的事件绑定命名空间
jQuery的bind的函数在实际应用中用的不是特别多,只是他可以绑定一个事件,但不会即时触发,也可以通过unbind来解除绑定.在没有看到这篇文章之前,我一直不知道原来bind也可以有命名空间.事实 ...
- jQuery中的事件绑定的几种方式
jQuery目前有on(),bind(),delegate(),live()四种绑定方式,但是随着版本的不断更新,有的方式也相应的被淘汰掉 [band()方式绑定] 3.0版本之前的绑定方式比较常用的 ...
- JQuery实现click事件绑定与触发方法分析
原生JS通过什么方法绑定click事件? 原生js有一下三种方法为DOM对象绑定click事件, 第一种,在html中添加 onclick属性,在此属性中添加要绑定的事件函数,如下, 这种方法为htm ...
随机推荐
- 【XSY2524】唯一神 状压DP 矩阵快速幂 FFT
题目大意 给你一个网格,每个格子有概率是\(1\)或是\(0\).告诉你每个点是\(0\)的概率,求\(1\)的连通块个数\(\bmod d=0\)的概率. 最开始所有格子的概率相等.有\(q\)次修 ...
- 【BZOJ4325】【NOIP2015】斗地主 搜索
题目描述 就是给你一副牌,问你最少几次能出完. 详细规则见规则 \(n\leq 23\) 题解 NOIP的数据非常水,错误一大堆的程序都能AC. 因为顺子对答案的影响最大,所以先枚举顺子进行搜索. 接 ...
- 允许外网访问MySQL
1:设置mysql的配置文件 /etc/mysql/my.cnf 找到 bind-address =127.0.0.1 将其注释掉://作用是使得不再只允许本地访问: 重启mys ...
- hiho1258 Osu! Master
题目链接:http://hihocoder.com/problemset/problem/1258 题目大意:看能连击的次数 思路:水 看有多少个1和s就好了 #include <stdio.h ...
- 扩展资源服务器解决oauth2 性能瓶颈
OAuth用户携带token 请求资源服务器资源服务器拦截器 携带token 去认证服务器 调用tokenstore 对token 合法性校验资源服务器拿到token,默认只会含有用户名信息通过用户名 ...
- [WC2008]游览计划 解题报告
[WC2008]游览计划 斯坦纳树板子题,其实就是状压dp 令\(dp_{i,s}\)表示任意点\(i\)联通关键点集合\(s\)的最小代价 然后有转移 \[ dp_{i,S}=\min_{T\in ...
- 如何搭建高可用redis架构?
如何搭建高可用redis架构? 温国兵 架构师小秘圈 昨天 作者:温国兵,曾任职于酷狗音乐,现为三七互娱 DBA.目前主要关注领域:数据库自动化运维.高可用架构设计.数据库安全.海量数据解决方案.以及 ...
- OpenLayers学习笔记(四)— QML显示html中openlayers地图的坐标
GitHub:八至 作者:狐狸家的鱼 本文链接:实现QML中显示html中地图的坐标 如何QML与HTML通信已经在这篇文章 QML与HTML通信之画图 详细讲述了 1.HTML var coord; ...
- Linux中OBS在Wayland环境下黑屏只显示鼠标的应对措施
本文写于2018-02-10.截至到此文完成时,没有已知的方法可以让OBS在Wayland环境下正常工作. 解决方法 放弃使用Wayland,改用X Window 在Wanyland上录制屏幕,可以使 ...
- java List<String> 转换成带逗号的字符串
使用commons-lang3-3.3.2.jar org.apache.commons.lang3.StringUtils.join(applyNameList, ",");