jQuery中bind和on绑定事件有什么区别和用法?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1010个文字,预计阅读时间需要5分钟。
原文示例讲述了jQuery绑定事件的方法bind和on的用法与区别。以下是改写后的内容:
jQuery绑定事件的方法bind和on都用于给元素绑定事件,但它们之间有区别。主要区别在于事件冒泡和委托事件的处理方式。
bind和on都可用于给元素绑定事件,但bind主要用于早期版本的jQuery,而on是jQuery 1.7及以上版本引入的新方法。
bind和on的区别:
1. 事件冒泡:bind和on都支持事件冒泡,即子元素上的事件会冒泡到父元素。
2. 委托事件:on方法支持委托事件,即可以在父元素上绑定事件,当子元素触发事件时,也会触发父元素上的事件。
总结:bind和on都是用于绑定事件的,但on方法支持事件冒泡和委托事件,是bind方法的高级替代。
本文实例讲述了jquery绑定事件 bind和on的用法与区别。分享给大家供大家参考,具体如下:
bind和on都是给元素绑定事件用的,其最大的区别就是事件冒泡
事件冒泡也是委托事件的原型,事件委托就是子类的事情委托给父类的去做
最直观的区别就是on绑定比bind绑定多一个参数'childSelector'
语法
$(selector).on(event,childSelector,data,function)
由空格分隔多个事件值,也可以是数组。必须是有效的事件。
$(selector).bind(event,data,function,map)
由空格分隔多个事件值。必须是有效的事件。
- bind只能给符合条件的元素本身添加事件
- on可以将子元素的事件委托给父元素进行处理,而且可以给动态添加的元素加上绑定事件
也就是对于新添加的元素如果是on绑定,符合条件的新元素也会绑定事件,
如果是bind则不影响新元素
比如下例:
<ul> <li>第一个子元素<li/> <li>第二个子元素<li/> <li>第三个子元素<li/> </ul>
我们想给所有li添加click事件,可以用on:
$('ul').on('click','li', function () { console.log($(this).text()); });
也可以用bind:
$('ul li').bind('click', function () { console.log($(this).text()); });
有什么区别呢?
第一用on绑定实际上是委托给了父级ul,也就是只给 一个元素绑定了事件
第二个是用选择器选择了ul下的所有li元素 依次绑定了事件
假如有很多很多子元素区别就很大了, bind会严重影响性能!
假如这时候新添一个li:
$('ul').append('<li>第四个子元素<li>');
- 如果是on绑定则这个li也会有点击事件
- 如果是bind则没有
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery页面元素操作技巧汇总》、《jQuery常见事件用法与技巧总结》、《jQuery常用插件及用法总结》、《jQuery扩展技巧总结》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
本文共计1010个文字,预计阅读时间需要5分钟。
原文示例讲述了jQuery绑定事件的方法bind和on的用法与区别。以下是改写后的内容:
jQuery绑定事件的方法bind和on都用于给元素绑定事件,但它们之间有区别。主要区别在于事件冒泡和委托事件的处理方式。
bind和on都可用于给元素绑定事件,但bind主要用于早期版本的jQuery,而on是jQuery 1.7及以上版本引入的新方法。
bind和on的区别:
1. 事件冒泡:bind和on都支持事件冒泡,即子元素上的事件会冒泡到父元素。
2. 委托事件:on方法支持委托事件,即可以在父元素上绑定事件,当子元素触发事件时,也会触发父元素上的事件。
总结:bind和on都是用于绑定事件的,但on方法支持事件冒泡和委托事件,是bind方法的高级替代。
本文实例讲述了jquery绑定事件 bind和on的用法与区别。分享给大家供大家参考,具体如下:
bind和on都是给元素绑定事件用的,其最大的区别就是事件冒泡
事件冒泡也是委托事件的原型,事件委托就是子类的事情委托给父类的去做
最直观的区别就是on绑定比bind绑定多一个参数'childSelector'
语法
$(selector).on(event,childSelector,data,function)
由空格分隔多个事件值,也可以是数组。必须是有效的事件。
$(selector).bind(event,data,function,map)
由空格分隔多个事件值。必须是有效的事件。
- bind只能给符合条件的元素本身添加事件
- on可以将子元素的事件委托给父元素进行处理,而且可以给动态添加的元素加上绑定事件
也就是对于新添加的元素如果是on绑定,符合条件的新元素也会绑定事件,
如果是bind则不影响新元素
比如下例:
<ul> <li>第一个子元素<li/> <li>第二个子元素<li/> <li>第三个子元素<li/> </ul>
我们想给所有li添加click事件,可以用on:
$('ul').on('click','li', function () { console.log($(this).text()); });
也可以用bind:
$('ul li').bind('click', function () { console.log($(this).text()); });
有什么区别呢?
第一用on绑定实际上是委托给了父级ul,也就是只给 一个元素绑定了事件
第二个是用选择器选择了ul下的所有li元素 依次绑定了事件
假如有很多很多子元素区别就很大了, bind会严重影响性能!
假如这时候新添一个li:
$('ul').append('<li>第四个子元素<li>');
- 如果是on绑定则这个li也会有点击事件
- 如果是bind则没有
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:tools.jb51.net/code/HtmlJsRun测试上述代码运行效果。
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery页面元素操作技巧汇总》、《jQuery常见事件用法与技巧总结》、《jQuery常用插件及用法总结》、《jQuery扩展技巧总结》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。

