亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript動畫原理之如何使用js進行動畫效果的實現(xiàn)

 更新時間:2023年04月06日 10:32:31   作者:Aic山魚  
在現(xiàn)在做頁面很多時候都會用上動畫效果,比如下拉菜單,側(cè)邊搜索欄,層的彈出與關(guān)閉等等,下面這篇文章主要給大家介紹了關(guān)于JavaScript動畫原理之如何使用js進行動畫效果實現(xiàn)的相關(guān)資料,需要的朋友可以參考下

前言

動畫對于我們來說都不陌生,css里面就有很多動畫,2d,3d等各種動畫,本篇主要是如何使用js實現(xiàn)動畫效果,如果本篇文章對你有幫助,點贊支持一下吧!

1.動畫原理

        1.獲得盒子當前位置

        2.讓盒子在當前位置加上1個移動距離

        3.利用定時器不斷重復(fù)這個操作

        4.加一個結(jié)束定時器的條件        

        5.注意該元素需要添加定位,才能使用element.style.left

<body>
    <div>
 
    </div>
    <script>
 
        var div = document.querySelector('div');
        var timer = setInterval(function () {
            if (div.offsetLeft >= 500) {
                clearInterval(timer);
            }
            div.style.left = div.offsetLeft + 2 + 'px';
        }, 30)
    </script>
</body>

主要核心就是利用定時器進行動畫的實現(xiàn)

2.動畫函數(shù)的封裝

<script>
        // 簡單動畫函數(shù)封裝
        function animate(obj, rug) {
            var timer = setInterval(function () {
                if (obj.offsetLeft >= rug) {
                    clearInterval(timer);
                }
                obj.style.left = obj.offsetLeft + 2 + 'px';
            }, 30)
        }
        var div = document.querySelector('div');
    animate(div,300);
    </script>

把這個動畫封裝成一個函數(shù),方便以后的使用,該封裝函數(shù)里的obj是哪個元素要進行動畫的實現(xiàn)rug是該元素要移動多少距離

3.給不同元素添加定時器

<body>
    <div>
 
    </div>
    <button>點擊走</button>
    <script>
        // 簡單動畫函數(shù)封裝
        // 給不同元素添加定時器
        function animate(obj, rug) {
            clearInterval(obj.timer);
            obj.timer = setInterval(function () {
                if (obj.offsetLeft >= rug) {
                    clearInterval(obj.timer);
                } else {
                    obj.style.left = obj.offsetLeft + 2 + 'px';
                }
            }, 30)
        }
        var div = document.querySelector('div');
        var but = document.querySelector('button');
        but.addEventListener('click', function () {
            animate(div, 200);
        })
    </script>

這樣就能實現(xiàn)多個元素進行動畫的使用了,并且每個元素都有屬于自己的定時器

4.緩動動畫原理

公式:目標值-現(xiàn)在的位置/10 ,作為每次的移動距離

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <style>
        div {
            position: absolute;
            left: 0;
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
</head>
<body>
    <button>點擊</button>
    <div></div>
    <script>
        function animate(obj, rug) {
            clearInterval(obj.timer);
            obj.timer = setInterval(function () {
                // 步長值
                var step = (rug - obj.offsetLeft) / 10;
                if (obj.offsetLeft == rug) {
                    clearInterval(obj.timer);
                } else {
                    obj.style.left = obj.offsetLeft + step + 'px';
                }
            }, 15)
        }
        var div = document.querySelector('div');
        var but = document.querySelector('button');
        but.addEventListener('click', function () {
            animate(div, 500);
        })
    </script>
</body>
 
</html>

5.給動畫添加回調(diào)函數(shù)

回調(diào)函數(shù)原理:函數(shù)可以作為一個參數(shù)。將這個函數(shù)作為參數(shù)傳到另一個函數(shù)里面 ,當那個函數(shù)執(zhí)行完之后,再執(zhí)行傳進去的這個函數(shù),這個過程就叫做回調(diào)。

當跑完800米后,會彈出一個框“hello”,這個就是在執(zhí)行完800米這個動畫后再次進行的函數(shù),這就是回調(diào)函數(shù)

6.動畫函數(shù)的使用

實現(xiàn)側(cè)邊欄滑動效果

當鼠標經(jīng)過slider就會讓con這 個盒子滑動到左側(cè)

當鼠標離開slider就會讓con這 個盒子滑動到右側(cè)

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./js/animate.js"></script>
    <style>
        .silder {
            margin-left: 1600px;
            text-align: center;
            position: relative;
            line-height: 100px;
            width: 100px;
            height: 100px;
            background-color: aqua;
        }
        span {}
 
        .con {
            position: absolute;
            top: 0;
            left: 0;
            z-index: -1;
            width: 200px;
            height: 100px;
            background-color: rgb(132, 0, 255);
        }
    </style>
</head>
<body>
    <div class="silder">
        <span>←</span>
        <div class="con">問題反饋</div>
    </div>
    <script>
        var silder = document.querySelector('.silder');
        var con = document.querySelector('.con');
        var span = document.querySelector('span');
        silder.addEventListener('mouseenter', function () {
            animate(con, -200, function () {
                span.innerHTML = '→';
            });
        })
        silder.addEventListener('mouseleave', function () {
            animate(con, 0, function () {
                span.innerHTML = '←';
            });
        })
    </script>
</body>
 
</html>

寫在最后

到此這篇關(guān)于JavaScript動畫原理之如何使用js進行動畫效果的實現(xiàn)的文章就介紹到這了,更多相關(guān)js實現(xiàn)動畫效果內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS實現(xiàn)簡單的九宮格抽獎

    JS實現(xiàn)簡單的九宮格抽獎

    這篇文章主要為大家詳細介紹了JS實現(xiàn)簡單的九宮格抽獎,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JavaScript相等運算符的九條規(guī)則示例詳解

    JavaScript相等運算符的九條規(guī)則示例詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript相等運算符的九條規(guī)則,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 小程序開發(fā)之模態(tài)框組件封裝

    小程序開發(fā)之模態(tài)框組件封裝

    這篇文章主要為大家詳細介紹了小程序開發(fā)之模態(tài)框組件封裝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • javascript數(shù)組去重3種方法的性能測試與比較

    javascript數(shù)組去重3種方法的性能測試與比較

    面試題中有一題數(shù)組去重,首先想到的是對象存鍵值的方法可是遇到不同類型又能轉(zhuǎn)換成同樣的字符串的就完了接下來為大家介紹下雙重循環(huán)/存鍵值和類型實現(xiàn)去重,感興趣的各位可以參考下哈
    2013-03-03
  • JavaScript中this機制是如何真正工作的

    JavaScript中this機制是如何真正工作的

    JavaScript中this機制提供了更優(yōu)雅的方式來隱含地“傳遞”一個對象引用,導(dǎo)致更加干凈的API設(shè)計和更容易的復(fù)用,this既不是函數(shù)自身的引用,也不是函數(shù)詞法作用域的引用,this實際上是在函數(shù)被調(diào)用時建立的一個綁定,它指向什么是完全由函數(shù)被調(diào)用的調(diào)用點來決定的
    2023-11-11
  • AngularJs 禁止模板緩存的方法

    AngularJs 禁止模板緩存的方法

    本篇文章主要介紹了AngularJs 禁止模板緩存的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • javascript使用location.search的示例

    javascript使用location.search的示例

    本文介紹javascript 使用location.search獲取當前地址欄參數(shù)的實例
    2013-11-11
  • JavaScript缺少insertAfter解決方案

    JavaScript缺少insertAfter解決方案

    這篇文章主要介紹了JavaScript缺少insertAfter解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • javascript實現(xiàn)彈幕墻效果

    javascript實現(xiàn)彈幕墻效果

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)彈幕墻效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • 前端進階JS數(shù)組高級用法大全教程示例

    前端進階JS數(shù)組高級用法大全教程示例

    這篇文章主要為大家介紹了前端進階JS數(shù)組高級用法教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07

最新評論