jQuery事件绑定和委托实例_jquery_自学php网

本文实例讲述了jQuery事件绑定和委托。分享给大家供大家参考。具体方法如下:

jQuery事件的绑定和委托可以用多种方法实现,on()  、 bind()  、 live()  、 delegate() ,还有one()。
 
有时我们可能会像下面这样绑定一个事件:

复制代码 代码如下: $("#div1").click(function() { 
    alert("点击后触发"); 
});

上面的事件绑定,我们可以通过多种方式去实现:
 
1. on()

复制代码 代码如下: //无数据参数 
$("p").on("click", function(){ 
alert( $(this).text() ); 
}); 
 
//有数据参数 
function myHandler(event) { 
alert(event.data.foo); 

$("p").on("click", {foo: "bar"}, myHandler)

与on()对应的是off(),用来移除事件绑定:

复制代码 代码如下: var foo = function () { 
  // code to handle some kind of event 
}; 
// ... now foo will be called when paragraphs are clicked ... 
$("body").on("click", "p", foo); 
 
// ... foo will no longer be called. 
$("body").off("click", "p", foo);

off():移除on()进行的绑定
one():只绑定一次。
 
2. bind()

参数:
(type,[data],function(eventObject))
type: 含有一个或多个事件类型的字符串,由空格分隔多个事件。比如"click"或"submit",还可以是自定义事件名。
data:作为event.data属性值传递给事件对象的额外数据对象
 
fn:绑定到每个匹配元素的事件上面的处理函数
 
(type,[data],false)
type:含有一个或多个事件类型的字符串,由空格分隔多个事件。比如"click"或"submit",还可以是自定义事件名。
data:作为event.data属性值传递给事件对象的额外数据对象
 
false: 将第三个参数设置为false会使默认的动作失效。
 
同时绑定多个事件类型:

复制代码 代码如下: $('#foo').bind('mouseenter mouseleave', function() { 
  $(this).toggleClass('entered'); 
});

同时绑定多个事件类型/处理程序:

复制代码 代码如下: $("button").bind({ 
  click:function(){$("p").slideToggle();}, 
  mouseover:function(){$("body").css("background-color","red");},   
  mouseout:function(){$("body").css("background-color","#FFFFFF");}   
});

你可以在事件处理之前传递一些附加的数据。

复制代码 代码如下: function handler(event) { 
  alert(event.data.foo); 

$("p").bind("click", {foo: "bar"}, handler)


通过返回false来取消默认的行为并阻止事件起泡。

复制代码 代码如下: $("form").bind("submit", function() { return false; })

bind存在的问题

如果表格中要绑定单击事件的有10列500行,那么查找和遍历5000个单元格会导致脚本执行速度明显变慢,而保存5000个td元素和相应的事件处理程序也会占用大量内存(类似于让每个人亲自站在门口等快递)。

在前面这个例子的基础上,如果我们想实现一个简单的相册应用,每页只显示50张照片的缩略图(50个单元格),用户点击“第x页”(或“下一页”)链接可以通过Ajax从服务器动态加载另外50张照片。在这种情况下,似乎使用.bind()方法为50个单元格绑定事件又可以接受了。

事实却不然。使用.bind()方法只会给第一页中的50个单元格绑定单击事件,动态加载的后续页面中的单元格都不会有这个单击事件。换句话说,.bind()只能给调用它的时候已经存在的元素绑定事件,不能给未来新增的元素绑定事件(类似于新来的员工收不到快递)。

事件委托可以解决上述两个问题。具体到代码上,只要用jQuery 1.3新增的.live()方法代替.bind()方法即可:

复制代码 代码如下: $("#info_table td").live("click",function(){/*显示更多信息*
返回顶部
跳到底部

Copyright 2011-2024 南京追名网络科技有限公司 苏ICP备2023031119号-6 乌徒帮 All Rights Reserved Powered by Z-BlogPHP Theme By open开发

请先 登录 再评论,若不是会员请先 注册