本文实例讲述了jQuery事件绑定和委托。分享给大家供大家参考。具体方法如下: jQuery事件的绑定和委托可以用多种方法实现,on() 、 bind() 、 live() 、 delegate() ,还有one()。 代码如下: $("#div1").click(function() { 上面的事件绑定,我们可以通过多种方式去实现: 代码如下: //无数据参数 与on()对应的是off(),用来移除事件绑定: 代码如下: var foo = function () { off():移除on()进行的绑定 参数: 代码如下: $('#foo').bind('mouseenter mouseleave', function() { 同时绑定多个事件类型/处理程序: 代码如下: $("button").bind({ 你可以在事件处理之前传递一些附加的数据。 代码如下: function handler(event) { 通过返回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(){/*显示更多信息* |
-
:
:
本站声明:网站内容来源于网络,如有侵权,请联系我们,我们将及时处理。
还没有人抢沙发呢~