javascript實現(xiàn)緩動動畫效果
本文實例為大家分享了javascript實現(xiàn)緩動動畫效果的具體代碼,供大家參考,具體內(nèi)容如下
實現(xiàn)思路
1、主要使用setInterval定時函數(shù)
2、給需要動畫的元素添加絕對定位和偏移量,注意它的父元素要給相對定位
3、多個元素執(zhí)行動畫,可以將動畫代碼封裝成一個函數(shù)
4、元素調(diào)用定時函數(shù),定時移動,定時函數(shù)里- - -計算出每次移動距離
公式:var step = (target - obj.offsetLeft) / 20;
obj 動畫對象, target 目標左偏移量,20 控制的是動畫速度,數(shù)值越大越慢,越小越快
5、定時函數(shù)里還可以接收回調(diào)函數(shù),有的話,動畫結(jié)束時執(zhí)行回調(diào)函數(shù)
6、注意定時函數(shù)里最前面寫上清除動畫的代碼- - -clearInterval(obj.timer);不寫的話,每次觸發(fā)元素動畫會效果疊加;寫上清除之前的動畫影響
代碼示例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>aninamate動畫</title> <style> * { margin: 0; padding: 0; } .content { width: 1000px; margin: 0 auto; } button { padding: 5px; margin: 60px 10px; border: 1px solid #666; outline-color: palevioletred; } .both { background-color: pink; color: #fff; background-color: palevioletred; } .box { position: relative; height: 210px; margin: 0px auto; background-color: #191b28; } .yutu { position: absolute; top: 0; left: 0; width: 180px; height: 210px; } .qiaojingjing { position: absolute; top: 0; left: 820px; width: 180px; height: 210px; } .word1 { display: none; position: absolute; top: -50px; left: 45%; } .word2 { display: none; position: absolute; top: -30px; left: 50%; } </style> </head> <body> <div class="content"> <button class="btn1">于途前進</button> <button class="btn2">喬晶晶前進</button> <button class="both">雙向奔赴</button> <button class="btn3">于途后退</button> <button class="btn4">喬晶晶后退</button> <div class="box"> <img src="images/于途.png" alt="" class="yutu"> <img src="images/喬晶晶.png" alt="" class="qiaojingjing"> <span class="word1">余生請多指教!</span> <span class="word2">余生請多指教!</span> </div> </div> <script> var btn1 = document.querySelector('.btn1'); var btn2 = document.querySelector('.btn2'); var btn3 = document.querySelector('.btn3'); var btn4 = document.querySelector('.btn4'); var both = document.querySelector('.both'); var yutu = document.querySelector('.yutu'); var qiaojingjing = document.querySelector('.qiaojingjing'); var word1 = document.querySelector('.word1'); var word2 = document.querySelector('.word2'); btn1.addEventListener('click', function() { animate(yutu, 340, function() { word1.style.display = 'block'; }); }); btn2.addEventListener('click', function() { animate(qiaojingjing, 520, function() { word2.style.display = 'block'; }); }); btn3.addEventListener('click', function() { animate(yutu, 0, function() { word1.style.display = 'none'; }); }); btn4.addEventListener('click', function() { animate(qiaojingjing, 820, function() { word2.style.display = 'none'; }); }); both.addEventListener('click', function() { animate(yutu, 340); animate(qiaojingjing, 520); word1.style.display = 'block'; word2.style.display = 'block'; }); // 動畫函數(shù) obj動畫對象, target目標左偏移量, callback回調(diào)函數(shù) function animate(obj, target, callback) { // 清除之前的動畫 clearInterval(obj.timer); obj.timer = setInterval(function() { // 計算出每次移動距離 var step = (target - obj.offsetLeft) / 20; // 步數(shù)取整 step = step > 0 ? Math.ceil(step) : Math.floor(step); obj.style.left = obj.offsetLeft + step + 'px'; if (obj.offsetLeft == target) { // 停止動畫 clearInterval(obj.timer); // 如果有回調(diào)函數(shù),執(zhí)行回調(diào)函數(shù) if (callback) { callback(); } } }, 30); } </script> </body> </html>
動畫效果:
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS實現(xiàn)橫向與豎向兩個選項卡Tab聯(lián)動的方法
這篇文章主要介紹了JS實現(xiàn)橫向與豎向兩個選項卡Tab聯(lián)動的方法,涉及JavaScript遍歷及動態(tài)修改頁面元素屬性的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09解決LayUI加上form.render()下拉框和單選以及復(fù)選框不出來的問題
今天小編就為大家分享一篇解決LayUI加上form.render()下拉框和單選以及復(fù)選框不出來的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09javascript實現(xiàn)checkBox的全選,反選與賦值
這篇文章主要介紹了javascript實現(xiàn)checkBox的全選,反選與賦值的方法,以實例形式詳細分析了實現(xiàn)的思路及對應(yīng)的html與js代碼的實現(xiàn)過程2015-03-03js 判斷瀏覽器類型 去全角、半角空格 自動關(guān)閉當前窗口
去全角、半角空格 自動關(guān)閉當前窗口等實現(xiàn)函數(shù)。2009-04-04Echarts實現(xiàn)點擊列表聯(lián)動餅圖的示例代碼
本文主要介紹了Echarts實現(xiàn)點擊列表聯(lián)動餅圖的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05