zoukankan      html  css  js  c++  java
  • jQuery的 delegate问题

    习惯了bind,用惯了live,就不习惯delegate了呀有木有...

    支持为动态生成的标签元素绑定事件也许就live和delegate了吧,不过新版本已经不支持live了,只有delegate

    delegate真的比较特殊呀,不同于其他事件绑定的风格。

    就因为习惯了之前的bind风格..栽了跟头

    简单的说就是大意了。

    delegate() 方法为指定的元素(属于被选元素的子元素)添加一个或多个事件处理程序,并规定当这些事件发生时运行的函数。

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

    语法

    $(selector).delegate(childSelector,event,data,function)
    参数描述
    childSelector 必需。规定要附加事件处理程序的一个或多个子元素。
    event

    必需。规定附加到元素的一个或多个事件。

    由空格分隔多个事件值。必须是有效的事件。

    data 可选。规定传递到函数的额外数据。
    function 必需。规定当事件发生时运行的函数。

    比如这段小代码啊

    <html>
    <head>
    <script type="text/javascript" src="/jquery/jquery.js"></script>
    <script type="text/javascript">
    $(document).ready(function(){
      $("div").delegate("button","click",function(){
        $("p").slideToggle();
      });
    });
    </script>
    </head>
    <body>
    <div style="background-color:red">
    <p>这是一个段落。</p>
    <button>请点击这里</button>
    </div>
    
    </body>
    </html>

    我老写成了

    $(document).ready(function(){
      $("div").delegate($("button"),"click",function(){
        $("p").slideToggle();
      });
    });

    子选择器不需要选择起来了..

    不然就像我那样出现不知名的错误(点击会触发click,但点击其他元素也会触发click...)

    mark..

  • 相关阅读:
    简单的JS控制button颜色随点击更改
    以 “月” 为单位的可以翻页的效果 显示为 2016年01月
    荷兰国旗 Flag of the Kingdom of the Netherlands
    最大连续子数组以及拓展
    Something Wrong or Something Right
    转载文章----十步完全理解SQL
    数据库关系代数练习题
    SQL server 2014安装以及解决连接数据库失败问题
    回文判断
    字符串的包含
  • 原文地址:https://www.cnblogs.com/imwtr/p/4499752.html
Copyright © 2011-2022 走看看