zoukankan      html  css  js  c++  java
  • js动态添加事件-事件委托

    作者:白狼 出处:http://www.manks.top/javascript-dynamic-event.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

    其所谓的动态添加事件实质就是指js中的事件委托。

    我们知道在js中,事件处理只能绑定在当前被选中的元素上,换句话也就是说,事件处理只能绑定在当前文档已经存在的元素上!但是,往往小伙伴们都会遇到一个问题就是,我的元素是后来动态添加到页面的,而我又想给该元素绑定事件,怎么处理?

    为了说明白这一问题,我们假设需要给后来添加到当前页面的元素添加click事件。

    解决这一问题的核心就是利用js的委托事件。委派事件的优势就是可以给未存在的元素绑定事件,而且委派事件往往开销也会更小!

    题外话:举一个最简单的例子:当页面上有1000个div的时候,如果直接给div绑定click事件,其会为1000个元素绑定事件。但是,如果用事件委托,只需要一个元素绑定事件即可。PS:希望啰里啰嗦能够让你明白事件委托的含义。

    我们只是想知道动态创建的元素如何添加事件,你说这么多做什么,做什么...

    好吧,言归正传,看具体实现:

    // 模拟动态创建元素li
    $.ajax({
        type: 'get',
        data: {},
        success: function () {                
            $('<li>').addClass('aaa').html('11111111').appendTo($('body'));
        },
    });
    
    // 给为我们刚刚动态创建的元素添加事件
    $(document).on('click', 'li[class=aaa]', function(){
        console.log('ddd');
    });

    查看原文

  • 相关阅读:
    sql server 跨库操作
    FPGA使用技巧
    MATLAB学习(3)
    FPGA统计摄像头输出-基于MD9T112
    zedboard VmodCAM 图像采集 HDMI输出显示
    VmodCAM图像采集 VGA显示
    EDK中如何使用ISE中生成的IP
    如何将HDL文件实例化到XPS中
    ubuntu下安装 Source insight
    VmodCAM 初始化
  • 原文地址:https://www.cnblogs.com/wwolf/p/5683465.html
Copyright © 2011-2022 走看看