jQuery動畫詳解

来源:https://www.cnblogs.com/smyhvae/archive/2018/02/05/8417728.html
-Advertisement-
Play Games

本文最初發表於 "博客園" ,併在 "GitHub" 上持續更新 前端的系列文章 。歡迎在GitHub上關註我,一起入門和進階前端。 以下是正文。 前言 jQuery提供的一組網頁中常見的動畫效果,這些動畫是標準的、有規律的效果;同時還提供給我們了自定義動畫的功能。 顯示動畫 方式一: 解釋:無參數 ...


本文最初發表於博客園,併在GitHub上持續更新前端的系列文章。歡迎在GitHub上關註我,一起入門和進階前端。

以下是正文。

前言

jQuery提供的一組網頁中常見的動畫效果,這些動畫是標準的、有規律的效果;同時還提供給我們了自定義動畫的功能。

顯示動畫

方式一:

    $("div").show();

解釋:無參數,表示讓指定的元素直接顯示出來。其實這個方法的底層就是通過display: block;實現的。

方式二:

    $("div").show(2000);

解釋:通過控制元素的寬高、透明度、display屬性,逐漸顯示,2秒後顯示完畢。

效果如下:

方式三:

    $("div").show("slow");

參數可以是:

  • slow 慢:600ms

  • normal 正常:400ms

  • fast 快:200ms

解釋:和方式二類似,也是通過控制元素的寬高、透明度、display屬性,逐漸顯示。

方式四:

    //show(毫秒值,回調函數;
    $("div").show(5000,function () {
        alert("動畫執行完畢!");
    });

解釋:動畫執行完後,立即執行回調函數。

總結:

上面的四種方式幾乎一致:參數可以有兩個,第一個是動畫的執行時長,第二個是動畫結束後執行的回調函數。

隱藏動畫

方式參照上面的show()方法的方式。如下:

    $(selector).hide();

    $(selector).hide(1000); 

    $(selector).hide("slow");

    $(selector).hide(1000, function(){});

顯示和隱藏的來回切換:

顯示和隱藏的來回切換採用的是toggle()方法:就是先執行show(),再執行hide()。

同樣是四種方式:

$(selector).toggle();

滑入和滑出

1、滑入動畫效果:(類似於生活中的捲簾門)

    $(selector).slideDown(speed, 回調函數);

解釋:下拉動畫,顯示元素。

註意:省略參數或者傳入不合法的字元串,那麼則使用預設值:400毫秒(同樣適用於fadeIn/slideDown/slideUp)

2 滑出動畫效果:

    $(selector).slideUp(speed, 回調函數);

解釋:上拉動畫,隱藏元素。

3、滑入滑出切換動畫效果:

    $(selector).slideToggle(speed, 回調函數);

參數解釋同show()方法。

舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        div {
            width: 300px;
            height: 300px;
            display: none;
            background-color: pink;
        }
    </style>

    <script src="jquery-1.11.1.js"></script>
    <script>
        $(function () {
            //點擊按鈕後產生動畫
            $("button:eq(0)").click(function () {

                //滑入動畫: slideDown(毫秒值,回調函數[顯示完畢執行什麼]);
                $("div").slideDown(2000, function () {
                    alert("動畫執行完畢!");
                });
            })

            //滑出動畫
            $("button:eq(1)").click(function () {

                //滑出動畫:slideUp(毫秒值,回調函數[顯示完畢後執行什麼]);
                $("div").slideUp(2000, function () {
                    alert("動畫執行完畢!");
                });
            })

            $("button:eq(2)").click(function () {
                //滑入滑出切換(同樣有四種用法)
                $("div").slideToggle(1000);
            })

        })
    </script>
</head>
<body>
<button>滑入</button>
<button>滑出</button>
<button>切換</button>
<div></div>

</body>
</html>

淡入淡出動畫

1、淡入動畫效果:

    $(selector).fadeIn(speed, callback);

作用:讓元素以淡淡的進入視線的方式展示出來。

2、淡出動畫效果:

    $(selector).fadeOut(1000);

作用:讓元素以漸漸消失的方式隱藏起來

3、淡入淡出切換動畫效果:

    $(selector).fadeToggle('fast', callback);

作用:通過改變透明度,切換匹配元素的顯示或隱藏狀態。

參數的含義同show()方法。

代碼舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        div {
            width: 300px;
            height: 300px;
            display: none;
            /*opacity: 1;*/
            background-color: pink;
        }
    </style>

    <script src="jquery-1.11.1.js"></script>
    <script>
        $(function () {
            //點擊按鈕後產生動畫
            $("button:eq(0)").click(function () {
//                //淡入動畫用法1:   fadeIn();   不加參數
                $("div").fadeIn();

//                //淡入動畫用法2:   fadeIn(2000);   毫秒值
//                $("div").fadeIn(2000);
//                //通過控制  透明度和display

                //淡入動畫用法3:   fadeIn(字元串);   slow慢:600ms   normal正常:400ms   fast快:200ms
//                $("div").fadeIn("slow");
//                $("div").fadeIn("fast");
//                $("div").fadeIn("normal");

                //淡入動畫用法4:   fadeIn(毫秒值,回調函數[顯示完畢執行什麼]);
//                $("div").fadeIn(5000,function () {
//                    alert("動畫執行完畢!");
//                });
            })

            //滑出動畫
            $("button:eq(1)").click(function () {
//                //滑出動畫用法1:   fadeOut();   不加參數
//                $("div").fadeOut();

//                //滑出動畫用法2:   fadeOut(2000);   毫秒值
//                $("div").fadeOut(2000);  //通過這個方法實現的:display: none;
//                //通過控制  透明度和display

                //滑出動畫用法3:   fadeOut(字元串);   slow慢:600ms   normal正常:400ms   fast快:200ms
//                $("div").fadeOut("slow");
//                $("div").fadeOut("fast");
//                $("div").fadeOut("normal");

                //滑出動畫用法1:   fadeOut(毫秒值,回調函數[顯示完畢執行什麼]);
//                $("div").fadeOut(2000,function () {
//                    alert("動畫執行完畢!");
//                });
            })

            $("button:eq(2)").click(function () {
                //滑入滑出切換
                //同樣有四種用法
                $("div").fadeToggle(1000);
            })

            $("button:eq(3)").click(function () {
                //改透明度
                //同樣有四種用法
                $("div").fadeTo(1000, 0.5, function () {
                    alert(1);
                });
            })
        })
    </script>
</head>
<body>
<button>淡入</button>
<button>淡出</button>
<button>切換</button>
<button>改透明度為0.5</button>
<div></div>

</body>
</html>

自定義動畫

    $(selector).animate({params}, speed, callback);

作用:執行一組CSS屬性的自定義動畫。

  • 第一個參數表示:要執行動畫的CSS屬性(必選)

  • 第二個參數表示:執行動畫時長(可選)

  • 第三個參數表示:動畫執行完後,立即執行的回調函數(可選)

代碼舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        div {
            position: absolute;
            left: 20px;
            top: 30px;
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>
        jQuery(function () {
            $("button").click(function () {
                var json = {"width": 500, "height": 500, "left": 300, "top": 300, "border-radius": 100};
                var json2 = {
                    "width": 100,
                    "height": 100,
                    "left": 100,
                    "top": 100,
                    "border-radius": 100,
                    "background-color": "red"
                };

                //自定義動畫
                $("div").animate(json, 1000, function () {
                    $("div").animate(json2, 1000, function () {
                        alert("動畫執行完畢!");
                    });
                });

            })
        })
    </script>
</head>
<body>
<button>自定義動畫</button>
<div></div>
</body>
</html>

停止動畫

    $(selector).stop(true, false);

裡面的兩個參數,有不同的含義。

第一個參數:

  • true:後續動畫不執行。

  • false:後續動畫會執行。

第二個參數:

  • true:立即執行完成當前動畫。

  • false:立即停止當前動畫。

PS:參數如果都不寫,預設兩個都是false。實際工作中,直接寫stop()用的多。

效果演示:

當第二個參數為true時,效果如下:

當第二個參數為false時,效果如下:

這個後續動畫我們要好好理解,來看個例子。

案例:滑鼠懸停時,彈出下拉菜單(下拉時帶動畫)

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
        }

        ul {
            list-style: none;
        }

        .wrap {
            width: 330px;
            height: 30px;
            margin: 100px auto 0;
            padding-left: 10px;
            background-color: pink;
        }

        .wrap li {
            background-color: green;
        }

        .wrap > ul > li {
            float: left;
            margin-right: 10px;
            position: relative;
        }

        .wrap a {
            display: block;
            height: 30px;
            width: 100px;
            text-decoration: none;
            color: #000;
            line-height: 30px;
            text-align: center;
        }

        .wrap li ul {
            position: absolute;
            top: 30px;
            display: none;
        }
    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>
        //入口函數
        $(document).ready(function () {
            //需求:滑鼠放入一級li中,讓他裡面的ul顯示。移開隱藏。
            var jqli = $(".wrap>ul>li");

            //綁定事件
            jqli.mouseenter(function () {
                $(this).children("ul").stop().slideDown(1000);
            });

            //綁定事件(移開隱藏)
            jqli.mouseleave(function () {
                $(this).children("ul").stop().slideUp(1000);
            });
        });
    </script>

</head>
<body>
<div class="wrap">
    <ul>
        <li>
            <a href="javascript:void(0);">一級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">一級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">一級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
    </ul>
</div>
</body>
</html>

效果如下:

上方代碼中,關鍵的地方在於,用了stop函數,再執行動畫前,先停掉之前的動畫。

如果去掉stop()函數,效果如下:(不是我們期望的效果)

stop方法的總結

當調用stop()方法後,隊列裡面的下一個動畫將會立即開始。
但是,如果參數clearQueue被設置為true,那麼隊列面剩餘的動畫就被刪除了,並且永遠也不會執行。

如果參數jumpToEnd被設置為true,那麼當前動畫會停止,但是參與動畫的每一個CSS屬性將被立即設置為它們的目標值。比如:slideUp()方法,那麼元素會立即隱藏掉。如果存在回調函數,那麼回調函數也會立即執行。

註意:如果元素動畫還沒有執行完,此時調用sotp()方法,那麼動畫將會停止。並且動畫沒有執行完成,那麼回調函數也不會被執行。

我的公眾號

想學習代碼之外的軟技能?不妨關註我的微信公眾號:生命團隊(id:vitateam)。

掃一掃,你將發現另一個全新的世界,而這將是一場美麗的意外:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 要求實現一個輕量級的在客戶端篩選的combobox,支持大數據量(超過1000個items),能快速檢索內容,並支持數據的設置和活動等基本操作。在這之前嘗試過使用Jquery UI的Autocomplete,但是當數據量太大時客戶端檢索速度太慢(甚至會導致瀏覽器卡死)。索性乾脆基於JQuery自己寫 ...
  • 一、命名規則說明 二、相對網頁外層重要部分css樣式命名 css命名其他說明 DIV+CSS命名小結:無論是使用“.”選擇符號開頭命名,還是使用“#”選擇符號開頭都無所謂,但我們最好遵循——主要的,重要的,特殊的,最外層的盒子用“#”選擇符號開頭命名,其他都用“.”選擇符號開頭命名,同時要考慮命名的 ...
  • JavaScript對象的創建方式 在JavaScript中,創建對象的方式包括兩種:對象字面量和使用new表達式。對象字面量是一種靈活方便的書寫方式,例如: 1 2 3 4 5 6 var o1 = { p:”I’m in Object literal”, alertP:function(){ a ...
  • 一、web框架 眾所周知,對於所有的Web應用,本質上其實就是一個socket服務端,用戶的瀏覽器其實就是一個socket客戶端。 上述通過socket來實現了其本質,而對於真實開發中的python web程式來說,一般會分為兩部分:伺服器程式和應用程式。伺服器程式負責對socket伺服器進行封裝, ...
  • 1、在vue官網下載一個vue.min.js;http://www.runoob.com/vue2/vue-install.html,菜鳥課程提供下載地址 2、新建一個文件夾,將vue.min.js放進去; 3、新建一個html,引入上面的js; 4、編寫代碼: ...
  • electron官網提供的demo項目,在npm install 的時候總是報錯顯示安裝失敗, 解決辦法:翻牆即可成功安裝。 ...
  • 上拉載入的思路 1 上拉載入是要把屏幕拉到最底部的時候觸發ajax事件請求數據 2.所有要獲取屏幕的高度 文檔的高度 和滾動的高度 下麵的代碼是已經做好了相容的可以直接拿來用 3.首先要預設載入第一頁,在window.onload調用upDown這個方法 4.當頁面滾到底部的時候觸發up()這個方法 ...
  • 前言:最近要使用百度地圖實現樓盤可視化的功能,因此最基礎的功能就是將地圖網格化以後實現不同地域的樓盤劃分; 1,自行去百度地圖的開放平臺申請秘鑰哈,這裡我就把自己的秘鑰貼出來了;ak=A3CklGvnFOjkAzKzay2dySgfdig0GKz4 2,新建一個簡單頁面,下麵我把自己的頁面貼出來 3 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...