博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Jquery动态绑定事件处理函数 bind / on / delegate
阅读量:6153 次
发布时间:2019-06-21

本文共 1362 字,大约阅读时间需要 4 分钟。

1、bind方法绑定的事件处理函数不会应用到后来添加到DOM中的新元素。比如你在用bind给页面元素绑定事件之后,又新添加了一些与之前绑定过事件的元素一样的DOM元素,但是这些事件并不能在新的DOM元素上有体现。

如:

$(document).ready(function(){      $("img").bind({          mouseenter:function(){                   $(this).css("border","thick solid red");           },           mouseout:function(){                  $(this).css("border","thick solid green");           }         });       $("#row").append("");      });

此时新插入的img并没有绑定事件。

2、on方法绑定事件,并非直接把事件处理函数绑定到目标元素上。实际上它是在document对象上绑定了一个事件处理函数,该函数在触发时检查触发事件的元素是否匹配选择器。一旦事件与元素匹配成功,就调用绑定的事件处理函数。实际上,on方法是努力的把事件处理函数绑定要新的元素上。

$(document).ready(function(){      $(document).on({          mouseenter:function(){                   $(this).css("border","thick solid red");           },           mouseout:function(){                  $(this).css("border","thick solid green");           }         },"img"); $("#row").append(""); });

但是,on方法绑定事件处理函数可能会有一个问题,在处理函数执行之前,我们需要等事件传播到document元素,与on方法相比delegate更直接、高效一些。

3、delegate方法绑定事件,允许我们在页面上指定任意一个元素作为监听事件的元素,只绑定一个事件处理函数,绑定速度相对于bind和on算更快的。

 

$(document).ready(function(){      $("#row").delegate("img",{              mouseenter:function(){
        $(this).css("border","thick solid red");       },       mouseout:function(){         $(this).css("border","thick solid green");       }     },);     $("#row").append(""); });

 

转载于:https://www.cnblogs.com/1rookie/p/7866882.html

你可能感兴趣的文章
js中var、let、const的区别
查看>>
腾讯云加入LoRa联盟成为发起成员,加速推动物联网到智联网的进化
查看>>
从Python2到Python3:超百万行代码迁移实践
查看>>
Windows Server已可安装Docker,Azure开始支持Mesosphere
查看>>
简洁优雅地实现夜间模式
查看>>
react学习总结
查看>>
微软正式发布PowerShell Core 6.0
查看>>
Amazon发布新的会话管理器
查看>>
InfoQ趋势报告:DevOps 和云计算
查看>>
舍弃Python,为什么知乎选用Go重构推荐系统?
查看>>
在soapui上踩过的坑
查看>>
MySQL的字符集和字符编码笔记
查看>>
ntpd同步时间
查看>>
must implement java.io.Serializable hessian
查看>>
Microsoft Licenses Flash Lite for Windows Mobile Users
查看>>
HDOJ 2020 绝对值排序
查看>>
HDOJ/HDU 2560 Buildings(嗯~水题)
查看>>
Maven编译时跳过Test
查看>>
Spring Boot 整合Spring Security 和Swagger2 遇到的问题小结
查看>>
[20170628]12C ORA-54032.txt
查看>>