jquery动态绑定on
来源:互联网 发布:高级软件测试面试linux 编辑:程序博客网 时间:2024/04/29 09:27
之前因为一些原因,一直用的是版本比较低的jquery。
这次项目用了一些插件需要的jquery版本较高,因此固定了1.11.3的版本。然后很惊喜的发现live已经在1.9版本干掉了。
看了一下发现,为了统一接口,减少jquery代码库,live bind trigger这些统一转移到on上边。
这确实是个好事,方便了我们这些入门级别的人去使用!
on(events,[selector],[data],fn)
events,[selector],[data],fnV1.7
events:一个或多个用空格分隔的事件类型和可选的命名空间,如"click"或"keydown.myPlugin" 。
selector:一个选择器字符串用于过滤器的触发事件的选择器元素的后代。如果选择的< null或省略,当它到达选定的元素,事件总是触发。
data:当一个事件被触发时要传递event.data给事件处理函数。
fn:该事件被触发时执行的函数。 false 值也可以做一个函数的简写,返回false。
events-map,[selector],[data]V1.7
events-map:个用字符串表示的,一个或多个空格分隔的事件类型和可选的命名空间,值表示事件绑定的处理函数。
selector:一个选择器字符串过滤选定的元素,该选择器的后裔元素将调用处理程序。如果选择是空或被忽略,当它到达选定的元素,事件总是触发。
data:当一个事件被触发时要传递event.data给事件处理函数。
之前bind都是这么用
<pre name="code" class="javascript">$("").bind("click",function(){}')
当第二个可选参数'selector'为null时,on()和bind()其实在用法上基本上没有区别,我们可以认为on()只是比bind()多了一个可选的'selector'参数,所以on()可以非常方便的换掉bind()
$("").on("click",function(){}')
我个人非常喜欢使用live(),因为它可以把事件绑定到当前以及以后添加的元素上面,省了很多的事情。当然delegate()也可以做类似的事情了。
live()的原理很简单:给所有匹配的元素附加一个事件处理函数,即使这个元素是以后再添加进来的也有效。因此我们也可以使用on()通过将事件绑定到document来达到live()一样的效果。
$('ul li').live('click', 'ul li', function() {});
on()的写法
$(document).on('click', 'ul li', function() {});这里的关键就是第二个参数'selector'在起作用了。它是一个过滤器的作用,只有被选中元素的后代元素才会触发事件。因此必须把事件绑定到存在的元素上,如果被选中的元素不存在的话,自然上绑定不上的,更别提过滤后台元素了。
delegate()是1.4引入的,目的是通过祖先元素来代理委派后代元素的事件绑定问题,某种程度上和live()优点相似。只不过live()是通过document元素委派,而delegate则可以是任意的祖先节点。使用on()实现代理的写法和delegate()基本一致。
$('ul').delegate( 'li','click', function() {});
$('ul ').on('click', 'li', function() {});除了第一个和第二个参数颠倒一下,其他还没有发现有什么区别
如果只是使用一次的话 建议用one绑定。
- jquery动态绑定on
- jquery的 on方法 绑定动态元素
- jquery 动态元素事件绑定 on
- jQuery on()给动态元素绑定事件
- jquery on 动态绑定点击事件
- jquery on方法 绑定动态元素 出现的问题
- [JavaScript] jquery on方法 绑定动态元素 出现的问题
- jQuery on 方法对于网页元素动态绑定好处
- jquery on 绑定所有元素(包括动态生成的)
- jquery 动态添加的元素绑定事件使用on
- jQuery使用on()方法给动态生成元素绑定事件
- jQuery on()方法给动态生成的元素绑定方法
- jquery插件动态生元素,绑定angularjs on-click事件
- jQuery on()方法绑定动态元素的点击事件
- jquery中on动态绑定阻止冒泡事件异常
- Jquery,1.7+后的版本使用.on()绑定事件,动态绑定事件,绑定未来事件
- jQuery事件绑定.on()
- jQuery事件绑定.on()
- 在ssh项目中,junit测试报错。
- 配置编译Python3.4 + OpenCV3.0 + OpenGL
- spring mvc 注解
- 解决jquery的datepicker的本地化以及Today问题
- RecyclerView下拉刷新实现
- jquery动态绑定on
- 关于指针与被指对象断联后最好赋空值的问题
- android studio Session 'app': Error Installing APK解决方案
- 订单合并(单选多选)遇到的问题
- VC2005报错:fatal error LNK1104: cannot open file 'uuid.lib'
- CDISC SDTM DV domain 学习笔记
- AFNetworking源码解析(一)
- 发布python代码模块
- JSTL(c标签)与Struts2(s标签)标签的常用功能对比