jquery为动态添加元素添加事件

参考:http://api.jquery.com/live/

以前我们定义事件,比如为元素定义单击事件是这样写的:
代码如下:

$('input').click(function () {
//处理代码
});
 


代码如下:

$('.clickme').bind('click', function() {
// Bound handler called.
});
 

但是这只能是对已经加载好的元素定义事件,那些后来添加插入的元素则需要另行绑定。即使你使用jquery的clone函数,它并不能将事件也复制(到目前为止我还不清楚它是为什么这样定义,是没法复制还是刻意这么处理,以防止出现某些异常,这还有待去分析一下jquery的源代码)。
现在,使用live你可以轻松搞定,

$('.clickme').live('click', function() { // Live handler called. });这样,你即使在后面动态插入的元素,也会被绑定事件,$('body').append('
Another target
');

定义和用法

live() 方法为被选元素附加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。

10年的武山网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整武山建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联从事“武山网站设计”,“武山网站推广”以来,每个客户项目都认真落实执行。

通过 live() 方法附加的事件处理程序适用于匹配选择器的当前及未来的元素比如由脚本创建的新元素)。

 

问题:使用jQuery的live()方法绑定事件,有时会出现重复绑定的情况,如,当点击一个按钮时,此按钮所绑定的事件会并执行n遍。

解决:使用die()方法,在live()方法绑定前,将此元素上的前面被绑定的事件统统解除,然后再通过live()方法绑定新的事件。

 

Js代码
  1. //先通过die()方法解除,再通过live()绑定
  2. $("#selectAll").die().live("click",function(){
  3. //事件运行代码
  4. });
//先通过die()方法解除,再通过live()绑定
$("#selectAll").die().live("click",function(){
		//事件运行代码
	});

die()方法简介:

 

Js代码

die([type], [fn])"WHITE-SPACE: normal">

die([type], [fn])

概述

jQuery 1.3新增。此方法与live正好完全相反。

如果不带参数,则所有绑定的live事件都会被移除。

你可以解除用live注册的自定义事件。

如果提供了type参数,那么会移除对应的live事件。

如果也指定了第二个参数function,则只移出指定的事件处理函数。

 


文章题目:jquery为动态添加元素添加事件
本文路径:http://csdahua.cn/article/jipejd.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流