web前端jQuery#学习笔记03

12、jQuery 事件注册
jQuery 为我们提供了方便的事件注册机制,是开发人员抑郁操作优缺点如下:

  • 优点: 操作简单,且不用担心事件覆盖等问题。
  • 缺点: 普通的事件注册不能做事件委托,且无法实现事件解绑,需要借助其他方法。
    event
$(function() {
    // 1. 单个事件注册
    $("div").click(function() {
        $(this).css("background", "purple");
    });
    $("div").mouseenter(function() {
        $(this).css("background", "skyblue");
    });
})

(1)jQuery 事件处理
因为普通注册事件方法的不足,jQuery又开发了多个处理方法,重点讲解如下:

  • on(): 用于事件绑定,目前最好用的事件绑定方法
  • off(): 事件解绑
  • trigger() / triggerHandler(): 事件触发

事件处理 on() 绑定事件

  • 因为普通注册事件方法的不足,jQuery又创建了多个新的事件绑定方法bind() / live() / delegate() / on()等,其中最好用的是: on()
    on1on2on3
$(function() {
    // (1) on可以绑定1个或者多个事件处理程序
    // $("div").on({
    //     mouseenter: function() {
    //         $(this).css("background", "skyblue");
    //     },
    //     click: function() {
    //         $(this).css("background", "purple");
    //     }
    // });
    $("div").on("mouseenter mouseleave", function() {
        $(this).toggleClass("current");
    });
  
    // (2) on可以实现事件委托(委派)
    // click 是绑定在ul 身上的,但是 触发的对象是 ul 里面的小li
    // $("ul li").click();
    $("ul").on("click", "li", function() {
        alert(11);
    });

    // (3) on可以给未来动态创建的元素绑定事件
    $("ol").on("click", "li", function() {
        alert(11);
    })
    var li = $("<li>我是后来创建的</li>");
    $("ol").append(li);
})

案例:发布微博案例

1.点击发布按钮, 动态创建一个小li,放入文本框的内容和删除按钮, 并且添加到ul 中。
2.点击的删除按钮,可以删除当前的微博留言。

  • 事件处理 off() 解绑事件
    当某个事件上面的逻辑,在特定需求下不需要的时候,可以把该事件上的逻辑移除,这个过程我们称为事件解绑。jQuery 为我们提供 了多种事件解绑方法:die() / undelegate() / off() 等,甚至还有只触发一次的事件绑定方法 one(),在这里我们重点讲解一下 off() ;
    off
$(function() {
    // 事件绑定
    $("div").on({
        click: function() {
            console.log("我点击了");
        },
        mouseover: function() {
            console.log('我鼠标经过了');
        }
    });
    $("ul").on("click", "li", function() {
        alert(11);
    });
  
    // 1. 事件解绑 off 
    // $("div").off();  // 这个是解除了div身上的所有事件
    $("div").off("click"); // 这个是解除了div身上的点击事件
    $("ul").off("click", "li");
  
    // 2. one() 但是它只能触发事件一次
    $("p").one("click", function() {
        alert(11);
    })
})
  • 事件处理 trigger() 自动触发事件
    有些时候,在某些特定的条件下,我们希望某些事件能够自动触发, 比如轮播图自动播放功能跟点击右侧按钮一致。可以利用定时器自动触发右侧按钮点击事件,不必鼠标点击触发。由此 jQuery 为我们提供了两个自动触发事件 trigger() 和 triggerHandler() ;
$(function() {
  // 绑定事件
  $("div").on("click", function() {
    alert(11);
  });

  // 自动触发事件
  // 1. 元素.事件()
  // $("div").click();会触发元素的默认行为
  
  // 2. 元素.trigger("事件")
  // $("div").trigger("click");会触发元素的默认行为
  $("input").trigger("focus");
  
  // 3. 元素.triggerHandler("事件") 就是不会触发元素的默认行为
  $("input").on("focus", function() {
    $(this).val("你好吗");
  });
  // 一个会获取焦点,一个不会
  $("div").triggerHandler("click");
  // $("input").triggerHandler("focus");
});

(2)jQuery 事件对象
jQuery 对DOM中的事件对象 event 进行了封装,兼容性更好,获取更方便,使用变化不大。事件被触发,就会有事件对象的产生。

$(function() {
    $(document).on("click", function() {
        console.log("点击了document");
    })
    $("div").on("click", function(event) {
        // console.log(event);
        console.log("点击了div");
        event.stopPropagation();
    })
})

注意:jQuery中的 event 对象使用,可以借鉴 API 和 DOM 中的 event 。

(3)jQuery 拷贝对象
jQuery中分别为我们提供了两套快速获取和设置元素尺寸和位置的API,方便易用,内容如下。

$(function() {
    // 1.合并数据
    var targetObj = {};
    var obj = {
        id: 1,
        name: "andy"
    };
    // $.extend(target, obj);
    $.extend(targetObj, obj);
    console.log(targetObj);
   
    // 2. 会覆盖 targetObj 里面原来的数据
    var targetObj = {
        id: 0
    };
    var obj = {
        id: 1,
        name: "andy"
    };
    // $.extend(target, obj);
    $.extend(targetObj, obj);
    console.log(targetObj); 
})

(4)jQuery 多库共存
实际开发中,很多项目连续开发十多年,jQuery版本不断更新,最初的 jQuery 版本无法满足需求,这时就需要保证在旧有版本正常运行的情况下,新的功能使用新的jQuery版本实现,这种情况被称为,jQuery 多库共存。

$(function() {
    // 让jquery 释放对$ 控制权 让用自己决定
    var suibian = jQuery.noConflict();
    console.log(suibian("span"));
})

13、jQuery 插件
jQuery 功能比较有限,想要更复杂的特效效果,可以借助于 jQuery 插件完成。 这些插件也是依赖于jQuery来完成的,所以必须要先引入
jQuery文件,因此也称为 jQuery 插件。
jQuery 插件常用的网站:

  1. jQuery 插件库 http://www.jq22.com/
  2. jQuery 之家 http://www.htmleaf.com/
    jQuery 插件使用步骤:
  3. 引入相关文件。(jQuery 文件 和 插件文件)
  4. 复制相关html、css、js (调用插件)。

bootstrap案例-阿里百秀

1.通过调用组件实现导航栏
2.通过调用插件实现登录
3.通过调用插件标签页实现 tab 栏

综合案例: toDoList案例分析

  1. 文本框里面输入内容,按下回车,就可以生成待办事项。
  2. 点击待办事项复选框,就可以把当前数据添加到已完成事项里面。
  3. 点击已完成事项复选框,就可以把当前数据添加到待办事项里面。
  4. 但是本页面内容刷新页面不会丢失。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值