bind(type, [data], fn) on(type,[selector],[data],fn)
可以看到2个函数的区别在于:是否支持selector这个参数值。由于javascript的事件冒泡特性,如果我们在父元素上注册了一个事件处理函数,当子元素上发生这个事件的时候,父元素上的事件处理函数也会被触发。如果使用on的时候, 不设置selector,那么on与bind就没有区别 了。
<p id="parent"> <input type="button" value="a" id="a"/> <input type="button" value="b" id="b"/> </p>
$("#parent").on("click","#a",function(){ alert($(this).attr("id")); });
可以看到:on()函数的参数selector就是为了在事件冒泡的时候,让父元素能够过滤掉子元素上发生的事件。如果使用了bind,那么就没有这个能力,子元素上发生的事件一定会触发父元素事件。
还有一点需要注意:on绑定的事件处理函数,对于未来新增的元素一样可以,和delegate效果相同,而bind则不行。
以上就是jquery on bind之间有什么区别的详细内容,更多请关注Gxl网其它相关文章!
查看更多关于jqueryonbind之间有什么区别的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://www.haodehen.cn/did40659