jQuery delegate() 方法

实例

单击 <div> 元素中的 <p> 元素时,更改所有 <p> 元素的背景色:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script src="https://libs.baidu.com/jquery/2.1.4/jquery.min.js"></script>
  5. <script>
  6. $(document).ready(function(){
  7. $("div").delegate("p", "click",function(){
  8. $("p").css("background-color", "pink");
  9. });
  10. });
  11. </script>
  12. </head>
  13. <body>
  14. <div style="background-color:yellow;">
  15. <p>这是 div 元素中的一段</p>
  16. </div>
  17. <p>这是一个段落</p>
  18. </body>
  19. </html>

定义与用法

delegate() 方法在 3.0 版中被弃用。改用 on() 方法。

delegate() 方法为作为选定元素的子元素的指定元素附加一个或多个事件处理程序,并指定事件发生时要运行的函数。

使用 delegate() 方法附加的事件处理程序将适用于当前和未来的元素(如脚本创建的新元素)。


语法

  1. $(selector).delegate(childSelector,event,data,function)
参数描述
childSelector必填。指定要将事件处理程序附加到的一个或多个子元素
event必填。 指定要附加到元素的一个或多个事件。
多个事件值用空格分隔。必须是有效的事件
data可选。指定要传递给函数的其他数据
function必填。指定事件发生时要运行的函数

更多实例

使用 delegate() 方法为尚未创建的元素添加事件处理程序。

将数据传递给自定义命名事件处理程序

分类导航