zoukankan      html  css  js  c++  java
  • jq给动态生成的标签绑定事件的几种方法

    经常遇到给动态生成的标签绑定事件不好用,自己简单测试总结了下,结论如下了:

    body>  
        <!-- 下面是用纯动态方式生成标签 -->  
        <div id="d2">  
            生成a标签  
        </div>  
        <div id="d3">  
            <input type="button" value="生成a标签" id="btn" />  
        </div>  
    </body>  
    <script>  
          
        $(function(){  
            $('#btn').bind('click', function(event) {  
                /* 在添加标签的同时给添加的标签绑定点击事件 */  
                $("<li>Hello</li>").appendTo("#d2");  
                });  
                  
                ///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用  
                $('li').bind('click', function(event) {  
               alert("haha");  ///根本不会触发这个方法  
                });  
        })  
    </script>  

    点击按钮,就会在d2中添加一个li标签,这个可以。

    但是,如果这样在初始化时,用bind方法给将来要动态生成的li标签绑定方法是无效的,点击生成的li标签,没有任何反应。

    因为bind方法只能给在执行它时已经存在的静态标签jq对象绑定事件,对未来动态添加的标签是无效的。

    这时,可以有几种方法来解决这个问题:

    方法一:

    <body>  
            <!-- 下面是用纯动态方式生成标签 -->  
            <div id="d2">  
                动态生成a标签  
            </div>  
              
            <div id="d3">  
                <input type="button" value="生成a标签" id="btn"/>  
                  
            </div>  
        </body>  
        <script>  
            $(function() {  
                ///点击按钮,给d2动态添加标签  
                $('#btn').bind('click', function() {  
                    /* 在添加标签的同时给添加的标签绑定点击事件 */  
                    $("<li onclick='show()'>Hello</li>").appendTo("#d2");  
                });  
          
            })  
          
            function show() {  
                alert($(this).text());///这样打印出的是空的,没有任何东西,但是方法是会触发的(不能这样打印自己)  
                alert("哈哈");  
            }  
        </script>  

    这种方法是在动态拼接时就拼接好js原生的要触发的事件,然后把事件方法定义在script标签中。这种方法可以触发li的点击事件。但是如果要用alert($(this).text())这种打印标签自己本身信息的东西的方法,是没有任何结果显示的。这个即使是静态的标签打印自己也是不会有显示的。

    要解决这个问题,可以用下面两种方法。

    方法二:

    <body>  
        <!-- 下面是用纯动态方式生成标签 -->  
        <div id="d2">  
            生成a标签  
        </div>  
          
        <div id="d3">  
            <input type="button" value="生成a标签" id="btn"/>  
        </div>  
    </body>  
    <script>  
        $(function(){  
            $('#btn').bind('click', function(event) {  
                /* 在添加标签的同时给添加的标签绑定点击事件 */  
                $("<li>Hello</li>").appendTo("#d2").bind('click', function() {  
                  /* 显示标签的内容 */  
                  alert($(this).text());  ///这种方式也可以正常打印出 hello  
                });  
                });  
                  
        })  
    </script>  

    这种方式是可以解决上面问题的。虽然它用的也是bind方法,但是注意,它是先有目的标签对象然后才调用的bind方法,所以也是好用的。而且它居然可以正常打印自己的信息,非常厉害。

    方法三:

    <body>  
            <!-- 下面是用纯动态方式生成标签 -->  
            <div id="d1">  
                测试静态标签的绑定方法  
            </div>  
            <br />  
              
            <div id="d2">  
                动态生成a标签的位置  
            </div>  
            <div id="d3">  
                <input type="button" value="生成a标签" id="btn" />  
            </div>  
        </body>  
        <script>  
            $(function(){  
                $('#btn').bind('click', function() {  
                    /* 在添加标签的同时给添加的标签绑定点击事件 */  
                    $("<li>Hello</li>").appendTo("#d2");  
                });  
                  
                ///bind方法对于动态添加的标签不好使,只对已经存在的静态标签好用  
                ///用live方法才好用  
                $('li').live('click', function() {  
                   alert($(this).text());///注意,用live还可以这样写,结果是正常的  
                   alert("haha");  
                });  
                  
                ///通过 live() 方法附加的事件处理程序适用于匹配选择器的当前及未来的元素(比如由脚本创建的新元素)  
                $('#d1').live('click', function() {///对于静态和动态创建的标签都好使  
                   alert($(this).text());///注意,用live还可以这样写,结果是正常的.这是非常重要的  
                   alert("haha");  
                });  
            })  
        </script>  

    这种就是用jq的非常好用的既可以动态也可以静态绑定现在或者未来各种标签的live方法。而且它最神奇的地方是也能 打印自己。我靠,太牛了。以后就用它了。

    暂时还没发现这个live方法有什么弱点啊!

  • 相关阅读:
    【大数据】Hadoop的伪分布式安装
    【运维】什么是EPEL?
    【架构】RESTful的架构思想
    【python】有关python的异或操作的分析
    【Python】有关os.path.dirname(__file__)的注意事项
    Python中字符串前添加r ,b, u, f前缀的含义
    【Confluence】在CentOS7上的安装小记(下)
    Redis应用场景
    spring的context:exclude-filter 与 context:include-filter
    Spring的<context:annotation-config>和<annotation-driven>
  • 原文地址:https://www.cnblogs.com/lst619247/p/8580142.html
Copyright © 2011-2022 走看看