实例方法:

  • 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使用(七):事件绑定与取消,及自定事件的实现原理的更多相关文章

  1. javascript 的事件绑定和取消事件

    研究fabricjs中发现,它提供canvas.on('mousemove', hh) 来绑定事件, 提供 canvas.off()来取消绑定事件这样的接口,很是方便, 那我们就不妨探究一下内在的实现 ...

  2. 事件绑定、取消的二种形式 & call

    <script> //call 函数下的一个方法,call方法第一个参数可以改变函数执行过程中的内部this的指向,call方法第二个参数开始就是原来函数的参数列表. function f ...

  3. 学习javaScript必知必会(4)~事件、事件绑定、取消事件冒泡、事件对象

    1.常用的事件: ① onload:页面加载 ② onblur: 失去焦点 onfocus: 获取焦点 ③ onclick:点击 ④ onmouseover:鼠标经过 onmouseout:鼠标离开 ...

  4. 事件绑定的快捷方式 利on进行事件绑定的几种情况

    [事件绑定快捷方式]$("button:first").click(function(){ alert(1); }); [使用on绑定事件] ① 使用on进行单事件绑定 $(&qu ...

  5. jQuery 中的事件绑定与取消绑定

    1:在jQuery中使用bind方法进行事件的绑定,bind方法有两个参数,第一个参数是事件的类型例如click,change,keyup,keydown,blur,focus等.第二个参数是一个回调 ...

  6. jQuery事件绑定的最佳实践

    如果你经常使用jQuery,那么你也许很熟悉事件绑定.这是很基本的东西,但是深入一点,你就能够找到机会让你事件驱动的代码变得不太零碎,并且更容易管理. 更好的选择器策略 让我们从基础的例子开始.下面的 ...

  7. jQuery的事件绑定命名空间

    jQuery的bind的函数在实际应用中用的不是特别多,只是他可以绑定一个事件,但不会即时触发,也可以通过unbind来解除绑定.在没有看到这篇文章之前,我一直不知道原来bind也可以有命名空间.事实 ...

  8. jQuery中的事件绑定的几种方式

    jQuery目前有on(),bind(),delegate(),live()四种绑定方式,但是随着版本的不断更新,有的方式也相应的被淘汰掉 [band()方式绑定] 3.0版本之前的绑定方式比较常用的 ...

  9. JQuery实现click事件绑定与触发方法分析

    原生JS通过什么方法绑定click事件? 原生js有一下三种方法为DOM对象绑定click事件, 第一种,在html中添加 onclick属性,在此属性中添加要绑定的事件函数,如下, 这种方法为htm ...

随机推荐

  1. ISAP算法

    为什么叫ISAP ISAP(Improved Shortest Augment Path):改进的最短增广路,属于增广路算法 算法 Dinic算法中,我们每次都需要BFS出层次图,而在ISAP中,我们 ...

  2. 【XSY2484】mex 离散化 线段树

    题目大意 给你一个无限长的数组,初始的时候都为\(0\),有3种操作: 操作\(1\)是把给定区间\([l,r]\)设为\(1\): 操作\(2\)是把给定区间\([l,r]\)设为\(0\): 操作 ...

  3. MySQL免安装版,遇到MSVCR120.dll文件丢失错误的解决方案

    下载 VC redist packages for x64,下载完成,点击运行即可.

  4. 【BZOJ2034】最大收益(贪心)

    [BZOJ2034]最大收益(贪心) 题面 BZOJ 题解 首先显然让价值越大的占用一个时刻一定更优. 所以把所有东西按照价值排序之后来处理,那么显然就是把前面的全部放好之后,考虑来放当前这个东西,如 ...

  5. 「浙大ACM」图森未来杯游记一篇以及简易口胡题解

    前言 蒟蒻有参加了ACM比赛,这一次有适合HY和慕容宝宝大佬一起比的,他们好巨啊,把我带飞了. 又是窝掌机,QAQ,他们仗着自己巨,就欺负窝... 我又打了\(4\)个小时的代码,而且那个键盘太恶心了 ...

  6. Nodejs nmp 常用命令

    npm是一个node包管理和分发工具,已经成为了非官方的发布node模块(包)的标准.有了npm,可以很快的找到特定服务要使用的包,进行下载.安装以及管理已经安装的包. 1.npm install m ...

  7. [luogu3810][bzoj3262][陌上花开]

    题目链接 思路 听说可以CDQ分治,然后我不会,所以我写树套树 首先肯定先按照a拍个序.然后就成了在b,c这两个数组中查询了.用一个树状数组套treap来维护.当插入一个数的时候,就在树状数组的b这个 ...

  8. “adb不是内部或外部命令,也不是可运行的程序或批量文件“

    首先这个问题有两种可能: 1.就是没有配置环境变量, 这个只需要将android安装:例如C:\Program File\android-sdk-windows\tools加入到 系统变量Path中, ...

  9. 第一篇-Git基础学习

    学习网址: https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013758410 ...

  10. 解决win10环境下python Selenuim调用Chrome时提示data 及Chrome正在受自动软件控制的方法

    用python自动访问谷歌浏览器时会出现data界面,很是烦人.在网上搜索,有说是因为webdriver和google版本不匹配导致的,就下过各种版本,结果都一样. 后来明白了,出现data的原因只是 ...