jquery 动态按钮绑定点击事件

一、Jquery实现点击事件的四种写法

来自:https://blog.csdn.net/liutianjie/article/details/85112787

1. $(".tab").click(function () {  })

2. $(".tab").on("click",function () {  })

3. $(document).on("click", ".tab",function () {  })

4. 使用<οnclick="">触发函数

以上四种方法在不同设备上的可行程度

自测。

3>2>1>4

二、jquery 给动态生成的标签绑定事件的几种方法总结

来自:https://www.jb51.net/article/135369.htm?utm_medium=referral

<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对象绑定事件,对未来动态添加的标签是无效的。

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

方法一:

    <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())这种打印标签自己本身信息的东西的方法,是没有任何结果显示的。这个即使是静态的标签打印自己也是不会有显示的。

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

方法二:

<script>
    $(function(){
        $('#btn').bind('click', function(event) {
         /* 在添加标签的同时给添加的标签绑定点击事件 */
         $("<li>Hello</li>").appendTo("#d2").bind('click', function() {
          /* 显示标签的内容 */
          alert($(this).text()); ///这种方式也可以正常打印出 hello
         });
        }); 
    })
</script>

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

方法三:(废)

<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>

 注:关于live方法的使用问题

定义和用法

live() 方法在 jQuery 版本 1.7 中被废弃,在版本 1.9 中被移除。请使用 on() 方法代替。

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

通过 live() 方法添加的事件处理程序适用于匹配选择器的当前及未来的元素(比如由脚本创建的新元素)。

提示:如需移除事件处理程序,请使用 die() 方法。(die()在版本 1.9 中被移除。移除所有通过 live() 方法添加的事件处理程序)

语法

$(selector).live(event,data,function)

jQuery中live()方法到on()方法的转变写法:https://blog.csdn.net/hu1010037197/article/details/79646974  作者: HaleyTiger

 

已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页