来源:自学PHP网 时间:2014-11-29 13:28 作者: 阅读:次
[导读] 这篇文章主要介绍了jQuery事件绑定和委托,以实例形式分析了jQuery事件绑定和委托中on()、bind()、live()、delegate()的用法,具有一定的学习与借鉴价值,需要的朋友可以参考下...
本文实例讲述了jQuery事件绑定和委托。分享给大家供大家参考。具体方法如下: jQuery事件的绑定和委托可以用多种方法实现,on() 、 bind() 、 live() 、 delegate() ,还有one()。 复制代码 代码如下: $("#div1").click(function() {
alert("点击后触发"); }); 上面的事件绑定,我们可以通过多种方式去实现: 复制代码 代码如下: //无数据参数
$("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()进行的绑定 参数: 复制代码 代码如下: $('#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)
复制代码 代码如下: $("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(){/*显示更多信息*
|
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com