工作笔记——jQuery的事件绑定
来源:互联网 发布:网上开店铺的软件 编辑:程序博客网 时间:2024/06/04 22:53
最近在工作中做了一个项目,需要完全由ajax搭建后台,每个ajax页面都会绑定事件。这时候发现点击多次ajax页面之后,点击页面中的按钮时会多次触发事件。经过多次尝试分析了解到,每个ajax页面都会在一个固定的div容器中输出,事件也绑定在这个div上,这时切换过几次页面之后,相当于在这个div容器上绑定了多次事件,当按下按钮时,就会发生事件触发多次的状况。 现在,在页面开始将事件绑定取消以解决这个问题。
绑定事件的jq方法有很多,有的在工作中不常用很容易忘,下面做些笔记。
常用的方法有4种:bind();live();delegate();on;
而对应的解除绑定的方法为:unbind();die();undelegate();off();
1.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);
2.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);
3.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);
4.看了这么多,那么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绑定事件的四种方式介绍,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
原文链接:http://www.cnblogs.com/lipenghui/p/6014669.html
- 工作笔记——jQuery的事件绑定
- jQuery的绑定事件
- jQuery的事件绑定
- jquery的绑定事件
- jquery的事件绑定
- JQuery事件的绑定
- jQuery的事件绑定
- jQuery学习笔记:事件绑定
- 工作积累(六)——jQuery实现DOM元素事件动态绑定
- JQUERY —— 绑定事件/获取下拉框的值
- 【笔记】jQuery中动态添加的元素事件绑定
- jQuery 中事件的绑定
- JQuery绑定事件的方法
- jquery绑定事件的方法
- jquery一次性事件的绑定
- jQuery的事件绑定与事件委托
- Jquery的事件绑定live方法在ios版的微信网站无法正常工作
- 《锋利的jQuery》学习笔记——jquery中的事件
- ActionBar 搜索,tab
- 定时任务调度工具之Quartz(一)
- c++ new 的相关
- UVA 10112
- 欢迎使用CSDN-markdown编辑器
- 工作笔记——jQuery的事件绑定
- android:TextView
- 机器学习:梯度下降算法
- 浅析Java类和数据结构中常用的方法
- UVA 539
- Git 出现的问题
- Java多线程--初始
- 【多媒体编解码】Openmax IL (二)Android多媒体编解码Component架构
- 关于spring mvc,spring data,spring,MongoDB整合框架的一些思考和常用注解