• 03 jQuery事件


    1.jQuery 事件注册

    单个事件注册

    语法

    element.事件(function(){})	
    
    $("div").click(function(){事件处理程序}) // 演示
    

    其他事件和元素基本一样

    比如mouseover、mouseout、blur、focus、change、keydown、keyup、resize、scroll 等

    2.jQuery事件处理

    2.1 事件处理 on() 绑定事件

    on() 方法在匹配元素上绑定一个或多个事件的事件处理函数

    element.on(events,[selector],fn)
    

    1.events:一个或多个用空格分隔的事件类型,如"click"或"keydown"

    2.selector:元素的子元素选择器

    3.fn:回调函数

    on()方法优势 1

    可以绑定多个事件,多个处理事件处理程序

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <script src="jquery.min.js"></script>
        <style>
            div {
                 100px;
                height: 100px;
                background-color: pink;
            }
            
            .current {
                background-color: skyblue;
            }
        </style>
    </head>
    
    <body>
        <div></div>
        <script>
            $(function() {
                // $("div").click(function() {
                //     // 1. 单个事件注册
                //     $(this).css("background", "red")
                // })z
                // $("div").mouseenter(function() {
                //     $(this).css("background", "skyblue")
                // })
    
                // 2.事件处理on
                // $("div").on({
                //     mouseenter: function() {
                //         $(this).css("background", "skyblue")
                //     },
                //     click: function() {
                //         $(this).css("background", "red")
                //     }
                // })
    
                // 3.如果事件处理方法都一样则使用如下办法
                $("div").on("mouseenter mouseleave", function() {
                    $(this).toggleClass("current")
                })
            })
        </script>
    </body>
    
    </html>
    

    on()方法优势 2

    可以事件委派,把原来加给子元素身上的事件绑定在父元素身上,把事件委派给父元素

    $("ul").on("click", "li", function() {
    alert(1)
    });
    

    on()方法优势 3

    动态创建事件函数

    // 动态绑定事件
    // $("ol li").click(function() {
    //     alert(1)
    // })
    $("ol").on("click", "li", function() {
        alert(1)
    })
    var li = $("<li>后来的li</li>")
    $("ol").append(li)
    

    演示 微博简易动态生成留言

    <!DOCTYPE html>
    <html>
    
    <head lang="en">
        <meta charset="UTF-8">
        <title></title>
        <style>
            * {
                margin: 0;
                padding: 0
            }
            
            ul {
                list-style: none
            }
            
            .box {
                 600px;
                margin: 100px auto;
                border: 1px solid #000;
                padding: 20px;
            }
            
            textarea {
                 450px;
                height: 160px;
                outline: none;
                resize: none;
            }
            
            ul {
                 450px;
                padding-left: 80px;
            }
            
            ul li {
                line-height: 25px;
                border-bottom: 1px dashed #cccccc;
                display: none;
            }
            
            input {
                float: right;
            }
            
            ul li a {
                float: right;
            }
        </style>
        <script src="jquery.min.js"></script>
        <script>
            $(function() {
                // 1.点击发布按钮, 动态创建一个小li,放入文本框的内容和删除按钮, 并且添加到ul 中
                $(".btn").on("click", function() {
                        var li = $("<li></li>")
                        li.html($("textarea").val() + "<a href='javascript:;'>删除</a>")
                        if ($("textarea").val() != "") {
                            $("ul").prepend(li)
                            li.slideDown()
                                // 文本框内清空
                            $(".txt").val("")
                        } else {
                            alert("不为空")
                        }
    
                    })
                    // 2.点击删除按钮,可以删除当前微博的留言li
                    // 因为留言是动态生成的 所以不可以用click
                $("ul").on("click", "a", function() {
                    $(this).parent().slideUp(function() {
                        $(this).remove()
                    })
                })
            })
        </script>
    </head>
    
    <body>
        <div class="box" id="weibo">
            <span>微博发布</span>
            <textarea name="" class="txt" cols="30" rows="10"></textarea>
            <button class="btn">发布</button>
            <ul>
            </ul>
        </div>
    </body>
    
    </html>
    

    2.2 事件处理 off() 解绑事件

    off() 方法可以移除通过 on() 方法添加的事件处理程序。

    $("p").off() // 解绑p元素所有事件处理程序 
     
    $("p").off( "click")  // 解绑p元素上面的点击事件 后面的 foo 是侦听函数名 
     
    $("ul").off("click", "li");   // 解绑事件委托 
    

    如果有的事件只想触发一次, 可以使用 one() 来绑定事件。

    2.3 自动触发事件 trigger()

    有些事件希望自动触发, 比如轮播图自动播放功能跟点击右侧按钮一致。可以利用定时器自动触发右侧按钮点击事件,不必鼠标 点击触发。

     element.click()  // 第一种简写形式 
    
    $("p").on("click", function () {   alert("hi~"); });  
     
    $("p").trigger("click"); // 此时自动触发点击事件,不需要鼠标点击 
    element.trigger("type") // 第二种自动触发模式
    

    有些事件希望自动触发, 比如轮播图自动播放功能跟点击右侧按钮一致。可以利用定时器自动触发右侧按钮点击事件,不必鼠标 点击触发。

    element.triggerHandler(type)  // 第三种自动触发模式 
    

    triggerHandler模式不会触发元素的默认行为,这是和前面两种的区别。

    3. jQuery 事件对象

    事件被触发,就会有事件对象的产生。

    element.on(events,[selector],function(event) {})

    阻止默认行为:event.preventDefault() 或者 return false

    阻止冒泡: event.stopPropagation()

    4. jQuery 对象拷贝

    如果想要把某个对象拷贝(合并) 给另外一个对象使用,此时可以使用 $.extend() 方法

    语法

     $.extend([deep], target, object1, [objectN])
    
    1. deep: 如果设为true 为深拷贝, 默认为false 浅拷贝
    2. target: 要拷贝的目标对象
    3. object1:待拷贝到第一个对象的对象。
    4. objectN:待拷贝到第N个对象的对象。
    5. 浅拷贝目标对象引用的被拷贝的对象地址,修改目标对象会影响被拷贝对象。
    6. 深拷贝,前面加true, 完全克隆,修改目标对象不会影响被拷贝对象

    5.jQuery 多库共存

    问题概述:

    jQuery使用$作为标示符,随着jQuery的流行,其他 js 库也会用这$作为标识符, 这样一起使用会引起冲突。
    客观需求:

    需要一个解决方案,让jQuery 和其他的js库不存在冲突,可以同时存在,这就叫做多库共存。
    jQuery 解决方案:

    1. 把里面的 $ 符号 统一改为 jQuery。 比如 jQuery(''div'')
    2. jQuery 变量规定新的名称:$.noConflict() var xx = $.noConflict();

    6.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 (调用插件)。
    • 瀑布流

    • 图片懒加载(图片使用延迟加载在可提高网页下载速度。它也能帮助减轻服务器负载)

    当我们页面滑动到可视区域,在显示图片

    • 全屏滚动(fullpage.js)

    gitHub: https://github.com/alvarotrigo/fullPage.js

    中文翻译网站: http://www.dowebok.com/demo/2014/77/

    7.bootstrap JS插件

    bootstrap 也是依赖于jQuery开发,因此里面的js插件使用,也必须引入jq

  • 相关阅读:
    微软小冰迎来了一个新姐妹:“欣小然”
    终极之战:Linux & Windows
    逆天!百度AI音箱重磅升级:最大梦想实现
    国货之光!百度飞桨与华为麒麟重磅合作
    4天如何完爆Kafka源码核心流程!
    免费P7架构师直播课!技术人员如何提升职场技能?
    ZooKeeper核心原理及应用场景
    IT自由职业者是怎么样的感受和体验
    系统梳理主流定时器算法实现的差异以及应用
    微服务架构中分布式事务实现方案怎样何取舍
  • 原文地址:https://www.cnblogs.com/xujinglog/p/13038034.html
Copyright © 2020-2023  润新知