jQuery绑定事件的四种方式介绍


Posted in Javascript onOctober 31, 2016

jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码。下面我们来看下jQuery中绑定事件的方式都有哪些。

jQuery中提供了四种事件监听方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。在开始看他们之前

一:bind(type,[data],function(eventObject))

bind是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义如下:

type:事件类型,如click、change、mouseover等;

data:传入监听函数的参数,通过event.data取到。可选;

function:监听函数,可传入event对象,这里的event是jQuery封装的event对象,与原生的event对象有区别,使用时需要注意

bind的源码:

bind: function( types, data, fn ) {
return this.on( types, null, data, fn );
}
$('#myol li').bind('click',getHtml);

bind的特点就是会把监听器绑定到目标元素上,有一个绑一个,在页面上的元素不会动态添加的时候使用它没什么问题。但如果列表中动态增加一个“列表元素5”,点击它是没有反应的,必须再bind一次才行。要想不这么麻烦,我们可以使用live。

jQuery还有一种事件绑定的简写方式如a.click(function(){});、a.change(function(){});等,它们的作用与bind一样,仅仅是简写而已。

二:live(type, [data], fn)

live的参数和bind一样,它又有什么蹊跷呢,我们还是先瞄一眼源码:

live: function( types, data, fn ) {
jQuery( this.context ).on( types, this.selector, data, fn );
return this;
}

可以看到live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。这个context是什么东西呢?其实就是元素的限定范围,看了下面的代码就清楚了:

$('#myol li').context; //document
$('#myol li','#myol').context; //document
$('#myol li',$('#myol')[0]); //ol

通常情况下,我们都不会像第三种方式那样使用选择器,所以也就认为这个context通常就是document了,即live方法把监听器绑定到了 document上了。不把监听器直接绑定在元素上,你是不是想起事件委托机制来了呢?若没有,可以点击这里回忆一下。live正是利用了事件委托机制来 完成事件的监听处理,把节点的处理委托给了document。在监听函数中,我们可以用event.currentTarget来获取到当前捕捉到事件的 节点。下面的例子来揭晓:

$('#myol li').live('click',getHtml);

三:live存在那样的缺点,所以我们就思考,既然老爷子负担那么重,可不可以别把监听器绑定在document上呢,绑定在就近的父级元素上不就好了。顺应正常逻辑,delegate诞生了。

参数多了一个selector,用来指定触发事件的目标元素,监听器将被绑定在调用此方法的元素上。看看源码:

delegate: function( selector, types, data, fn ) {
return this.on( types, selector, data, fn );
}

又是调用了on,并且把selector传给了on。看来这个on真的是举足轻重的东西。照样先不管它。看看示例先:

$('#myol').delegate('li','click',getHtml);

看了这么多,你是不是迫不及待想看看这个on的真实面目了呢,这就来:

on(type,[selector],[data],fn)

参数与delegate差不多但还是有细微的差别,首先type与selector换位置了,其次selector变为了可选项。交换位置的原因不好查证,应该是为了让视觉上更舒服一些吧。

我们先不传selector来看一个例子:

$('#myol li').on('click',getHtml);

可以看到event.currentTarget是li自己,与bind的效果一样。至于传selector进去,就是跟delegate一样的意义了,除了参数顺序不同,其他完全一样。

终于看到on的真实作用了,那么,这么多的事件绑定方式,我们该如何进行选择呢?

其实这个问题是完全不必纠结的,因为你已经知道他们之间的区别了不是么?根据实际情况斟酌使用就行。不过官方有一个推荐就是尽量使用on,因为其他 方法都是内部调用on来完成的,直接使用on可以提高效率,而且你完全可以用on来代替其他三种写法。至于如何代替我想就不必这么直白的写出来了,真正理 解它们的区别之后自然而然也就不是难事了。

以上所述是小编给大家介绍的jQuery绑定事件的四种方式介绍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript模拟select,jselect的方法实现
Nov 08 Javascript
js中typeof的用法汇总
Dec 12 Javascript
深入理解javascript中的立即执行函数(function(){…})()
Jun 12 Javascript
javascript中解析四则运算表达式的算法和示例
Aug 11 Javascript
PHP中使用微秒计算脚本执行时间例子
Nov 19 Javascript
JS对HTML表格进行增删改操作
Aug 22 Javascript
详解js的事件处理函数和动态创建html标记方法
Dec 16 Javascript
详解Html a标签中href和onclick用法、区别、优先级别
Jan 16 Javascript
老生常谈js-react组件生命周期
May 02 Javascript
three.js 入门案例详解
Jan 23 Javascript
小程序实现tab标签页
Nov 16 Javascript
JS指定音频audio在某个时间点进行播放
Nov 28 Javascript
JS 实现导航菜单中的二级下拉菜单的几种方式
Oct 31 #Javascript
JS中作用域和变量提升(hoisting)的深入理解
Oct 31 #Javascript
jsp 网站引入外部css或者js失效问题解决
Oct 31 #Javascript
js学习笔记之事件处理模型
Oct 31 #Javascript
基于JS实现checkbox全选功能实例代码
Oct 31 #Javascript
新手学习前端之js模仿淘宝主页网站
Oct 31 #Javascript
vue.js学习笔记之绑定style样式和class列表
Oct 31 #Javascript
You might like
PHP5中的时间相差8小时的解决办法
2008/03/28 PHP
smarty section简介与用法分析
2008/10/03 PHP
IP攻击升级,程序改进以对付新的攻击
2010/11/23 PHP
Drupal7中常用的数据库操作实例
2014/03/02 PHP
PHP date()函数警告: It is not safe to rely on the system解决方法
2014/08/20 PHP
PHP的cURL库简介及使用示例
2015/02/06 PHP
Laravel 5.3 学习笔记之 错误&日志
2016/08/28 PHP
JavaScript DOM基础
2015/04/13 Javascript
探究Javascript模板引擎mustache.js使用方法
2016/01/26 Javascript
基于chosen插件实现人员选择树搜索自动筛选功能
2016/09/24 Javascript
jquery中关于bind()方法的使用技巧分享
2017/03/30 jQuery
ES6(ECMAScript 6)新特性之模板字符串用法分析
2017/04/01 Javascript
小程序中英文混合排序问题解决
2019/08/02 Javascript
Javascript操作select控件代码实例
2020/02/14 Javascript
Vue实现随机验证码功能
2020/12/29 Vue.js
[02:07]2017国际邀请赛中国区预选赛直邀战队前瞻
2017/06/23 DOTA
python简单程序读取串口信息的方法
2015/03/13 Python
浅谈Python的文件类型
2016/05/30 Python
python音频处理用到的操作的示例代码
2017/10/27 Python
解决Spyder中图片显示太小的问题
2018/04/27 Python
详解Python 切片语法
2019/06/10 Python
Python 一键获取百度网盘提取码的方法
2019/08/01 Python
解决IDEA 的 plugins 搜不到任何的插件问题
2020/05/04 Python
Jupyter Notebook安装及使用方法解析
2020/11/12 Python
python爬虫 requests-html的使用
2020/11/30 Python
详解Python+Selenium+ChromeDriver的配置和问题解决
2021/01/19 Python
聊聊python在linux下与windows下导入模块的区别说明
2021/03/03 Python
css3 按钮样式简单可扩展创建
2013/03/18 HTML / CSS
css3 实现圆形旋转倒计时
2018/02/24 HTML / CSS
Canvas 文本转粒子效果的实现代码
2019/02/14 HTML / CSS
prAna官网:瑜伽、旅行和冒险服装
2019/03/10 全球购物
static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?
2015/02/22 面试题
学校交通安全责任书
2014/08/25 职场文书
2014教师党员自我评议(5篇)
2014/09/20 职场文书
详解python字符串驻留技术
2021/05/21 Python
windows系统搭建WEB服务器详细教程
2022/08/05 Servers