zoukankan      html  css  js  c++  java
  • jQuery,使用on代替delegate,live 写法区别

    早期对页面上后期加载的动态元素,赋事件或值的时候,是使用live的.  由于效率比较低(其实数据不多也感觉不出来),后面使用delegate委托来代替了,再后面,1.7以后使用on 来代替delegate了. live,delegate在新版本中都还可以用. 它们在写法上有差别,一段时间不写容易混,写下来备忘. 如点击div里的任意一个button时增加一个新button:

    脚本:

    1.1 使用live

    jQuery版本1.3+

    $('.btnAdd').live('click', function () {
        $(this).clone().appendTo('#panel');
    });

    1.2 直接把live改成on, 没有给范围比如#panel,这对页面上一开始有的按钮有效. 也就是说无法直接这样代替live

    $('.btnAdd').on('click', function () {
        $(this).clone().appendTo('#panel');
    });

    2.使用delegate 需要给它一个范围才行,如#panel,让它到里面找.这样可以实现live一样的效果.

    jQuery版本1.4.3+

    $('#panel').delegate('.btnAdd', 'click', function () {
        $(this).clone().appendTo('#panel');
    });

    3.使用on 给它一个范围才行,如#panel,让它到里面找. 这样可以实现live和delegate一样的效果.

    里面的'click', '.btnAdd'跟上面的delegate是相反的.只要记住on click是挨在一起的就行了.

    jQuery版本1.7+

    $('#panel').on('click', '.btnAdd', function () {
        $(this).clone().appendTo('#panel');
    });
  • 相关阅读:
    PL/SQL Developer连接Oracle
    Oracle 11g 监听命令
    Oracle 11g的登陆问题
    PL/SQL Developer 配置和使用
    KMP应用求两个字符串的最长公共子串
    msc pool概念
    nformix调优之执行计划取得
    lsof 与fuser
    informix onstat命令收集
    各类系统上查看占cpu最多的进程
  • 原文地址:https://www.cnblogs.com/lichuntian/p/4793941.html
Copyright © 2011-2022 走看看