zoukankan      html  css  js  c++  java
  • jQuery为DOM动态追加事件

    处理一个列表绑定,因为是一个展示项目,没有使用复杂的插件,直接jsrender写了个模板,但是后面有一个操作按钮,去查看数据详情,想到了jquery使用on进行事件委托,然后就开搞

    最初是这样写的:

    $(".btn-open").on("click", function () {
                    alert($(this).text());
                })

    当然这样是不起作用的,因为在document reday后,.btn-open 这个元素根本还不存在呢,列表没绑定,事件当然也帮不上的!

    然后是这样的:

    $(".table").on("click", ".btn-open", function () {
                    alert($(this).text());
                })

    代码可以看得明白,找到.table 元素,给.btn-open 追加 click事件。一般来说这样就可以了。但是依然不行,我勒个去,我开始怀疑自己的记忆了。然后去找了下文档。

    文档说:

    事件处理只能绑定在当前被选中的元素上;而且,在您的代码调用.on()的时候,他们必须在页面文档中已经存在。

    好吧,在document ready时,.table确实不存在,所以 还要继续改

    $(document).on("click", ".btn-open", function () {
                    alert($(this).text());
                })

    终于可以工作了。

    总结:

    1.jQuery委托事件与直接绑定事件的区别:

    $(“X”).on(“click”,function(){})

    $(“X”).on(“click”,”选择X的子元素”,function(){})

     

    2.事件处理只能绑定到当前存在的元素身上,也就是第一个选择器中的内容必须当前存在(这也是为什么第二段代码不起作用的原因,因为.table不存在),所以保险起见,可以直接绑定委托事件到document上。

     

    以前一直没有仔细的阅读文档,对这一块模棱两可,今天弄清楚并记录下来。

     

    提醒自己:请阅读文档,然后再去怀疑人生!

  • 相关阅读:
    【题解】洛谷P5048 Yuno loves sqrt technology III
    【题解】Codeforces1545D AquaMoon and Wrong Coordinate
    Linux压缩解压命令汇总
    Linux设置DNS地址及清理DNS缓存方法
    Linux设置系统运行模式
    JDBC 1.0
    iBATIS 历史三个版本小细节对比
    Oracle import/Export 命令
    初创互联网团队如何利用开源技术和云服务快速建立网站
    oracle Merge 函数
  • 原文地址:https://www.cnblogs.com/buyixiaohan/p/6402190.html
Copyright © 2011-2022 走看看