1. 程式人生 > >03-jQuery動畫效果

03-jQuery動畫效果

order jquery char strong click mar 之前 停止 rip

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

顯示動畫

方式一:

  $("div").show();

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

方式二:

$(‘div‘).show(3000);

解釋:通過控制元素的寬高、透明度、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(){});

實現點擊按鈕顯示盒子,再點擊按鈕隱藏盒子

代碼如下:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            #box{
                width: 200px;
                height: 200px;
                background-color: green;
                border: 1px solid red;
                display: none;
            }
        </style>
    </head>
    <body>
        <div id="box">        
        </div>
        <button id="btn">隱藏</button>    
    </body>
    <script src="jquery-3.3.1.js"></script>
    
    <script type="text/javascript">
        
        //jquery 提供了一些方法 show() hide() 控制元素顯示隱藏
        var isShow = true;
        $(‘#btn‘).click(function(){
            if(isShow){
                $(‘#box‘).show(‘slow‘,function(){
                    $(this).text(‘盒子出來了‘);            
                    $(‘#btn‘).text(‘顯示‘);
                    isShow = false;
                })
            }else{
                $(‘#box‘).hide(2000,function(){
                    $(this).text(‘‘);    
                    $(‘#btn‘).text(‘隱藏‘);
                    isShow = true;
                    
                })
            }
        })
    
        
    </script>
</html>

開關式顯示隱藏動畫

$(‘#box‘).toggle(3000,function(){});

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

代碼如下:

    $(‘#btn‘).click(function(){
            $(‘#box‘).toggle(3000,function(){
                $(this).text(‘盒子出來了‘);    
                if ($(‘#btn‘).text()==‘隱藏‘) {
                    $(‘#btn‘).text(‘顯示‘);    
                }else{
                    $(‘#btn‘).text(‘隱藏‘);    
                }
            });
        })

滑入和滑出

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

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

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

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

2、滑出動畫效果:

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

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

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

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

代碼如下:

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

    <script src="jquery-3.3.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: 0.5;
            background-color: red;
        }
    </style>

    <script src="jquery-3.3.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: green;
        }
    </style>
    <script src="jquery-3.3.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()用的多。

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

<!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-3.3.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);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
                <li><a href="javascript:void(0);">二級菜單4</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">二級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
                <li><a href="javascript:void(0);">二級菜單4</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">三級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">三級菜單2</a></li>
                <li><a href="javascript:void(0);">三級菜單3</a></li>
                <li><a href="javascript:void(0);">三級菜單4</a></li>
            </ul>
        </li>
    </ul>
</div>
</body>
</html>

ps:

javascript:void(0); //跟javascript:;效果一樣

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

03-jQuery動畫效果