js定時(shí)器+簡(jiǎn)單的動(dòng)畫(huà)效果實(shí)例
1.向下滑動(dòng)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>向下滑動(dòng)</title> <style> body { margin: 0px; } #show { width: 200px; /* 高度為 0 */ height: 100px; background-color: lightcoral; margin: 0 auto; /* 設(shè)置為隱藏 */ /*display: none;*/ } </style> </head> <body> <div id="show"></div> <script> var show = document.getElementById('show'); /*show.style.display = 'block'; var t = setInterval(function(){ var style = window.getComputedStyle(show,null); var height = parseInt(style.height); // 判斷當(dāng)前的高度是否為 400 if (height >= 400){ clearInterval(t); } else { height++; show.style.height = height + 'px'; } },50);*/ slideDown(show,400); /* 將上述實(shí)現(xiàn)的向下滑動(dòng)效果,封裝在一個(gè)固定的函數(shù)中 * 設(shè)計(jì)當(dāng)前實(shí)現(xiàn)向下滑動(dòng)效果函數(shù)的形參 * elem - 表示實(shí)現(xiàn)向下滑動(dòng)效果的元素 * maxHeight - 表示元素向下滑動(dòng)的最大高度值 * 函數(shù)的邏輯與默認(rèn)設(shè)置CSS樣式屬性的值無(wú)關(guān) */ function slideDown(elem, maxHeight){ // 操作的元素默認(rèn)的display值為none elem.style.display = 'block'; elem.style.height = '0px'; var t = setInterval(function(){ var style = window.getComputedStyle(elem,null); var height = parseInt(style.height); // 判斷當(dāng)前的高度是否為 400 if (height >= maxHeight){ clearInterval(t); } else { height++; elem.style.height = height + 'px'; } },50); } </script> </body> </html>
2.移動(dòng)效果
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>移動(dòng)效果</title> <style> body { margin: 0px; } #box { width: 100px; height: 100px; background-color: lightcoral; position: absolute; left: 100px; top: 100px; } </style> </head> <body> <div id="box"></div> <script> var box = document.getElementById('box'); box.onclick = function(){ clearInterval(t); } /* * 向右移動(dòng) * 當(dāng)前元素移動(dòng)到頁(yè)面的最右邊時(shí) -> 向左移動(dòng) * 向左移動(dòng) * 當(dāng)前元素移動(dòng)到頁(yè)面的最左邊時(shí) -> 向右移動(dòng) */ var flag = false;// 默認(rèn)表示向右 var speed = 1;// 表示每次變化的值 t = setInterval(function(){ //speed += 0.01; // 獲取當(dāng)前頁(yè)面的寬度 var WIDTH = window.innerWidth; var style = window.getComputedStyle(box,null); var left = parseInt(style.left); var width = parseInt(style.width); // 判斷當(dāng)前元素移動(dòng)的方向 if (flag){// 向左移動(dòng) left -= speed; } else {// 向右移動(dòng) left += speed; } // 判斷什么情況下,向左移動(dòng);判斷什么情況下,向右移動(dòng) if ((left + width) >= WIDTH){// 向左移動(dòng) flag = true; } else if (left <= 0){// 向右移動(dòng) flag = false; } box.style.left = left + 'px'; },10); </script> </body> </html>
3.事件與動(dòng)畫(huà)結(jié)合
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>事件與動(dòng)畫(huà)結(jié)合</title> <style> body { margin: 0px; } </style> </head> <body> <script> // 獲取<body>元素 var body = document.body; // 當(dāng)頁(yè)面加載完畢后,設(shè)置當(dāng)前<body>元素的高度為當(dāng)前瀏覽器窗口的高度 window.onload = function(){ setHeight(body); }; // 當(dāng)用戶改變?yōu)g覽器窗口的大小時(shí),重新設(shè)置<body>元素的高度(等于當(dāng)前窗口的高度) window.onresize = function(){ setHeight(body); }; // 定義函數(shù) - 設(shè)置<body>元素的高度等于當(dāng)前窗口的高度 function setHeight(elem){ elem.style.height = window.innerHeight + 'px'; } var width = 100,height = 100; // 為<body>元素綁定click事件 body.onclick = function(event){ var x = event.clientX; var y = event.clientY; // 創(chuàng)建<div>元素,顯示的位置在鼠標(biāo)當(dāng)前的坐標(biāo)值 var div = document.createElement('div'); div.setAttribute('class','circle'); body.appendChild(div); // rgb(0,0,0)格式 -> 顏色隨機(jī) var r = parseInt(Math.random()*255); var g = parseInt(Math.random()*255); var b = parseInt(Math.random()*255); div.style.width = width + 'px'; div.style.height = height + 'px'; div.style.backgroundColor = 'rgb('+r+','+g+','+b+')'; div.style.borderRadius = '50%'; div.style.opacity = 1; div.style.position = 'absolute'; div.style.left = x - width/2 + 'px'; div.style.top = y - height/2 + 'px'; animate(div); } // 定義函數(shù) -> 實(shí)現(xiàn)動(dòng)畫(huà)效果 function animate(elem){ var style = window.getComputedStyle(elem,null); /*var width = parseInt(style.width); var height = parseInt(style.height); var left = parseInt(style.left); var top = parseInt(style.top); width++; height++; elem.style.width = width + 'px'; elem.style.height = height + 'px'; elem.style.left = (left - 0.5) + 'px'; elem.style.top = (top - 0.5) +'px';*/ var opacity = style.opacity; if (opacity <= 0){ clearTimeout(t); // 刪除當(dāng)前元素 } opacity -= 0.01; elem.style.opacity = opacity; // 設(shè)定定時(shí)器 var t = setTimeout(function(){ animate(elem); },50); } </script> </body> </html>
以上這篇js定時(shí)器+簡(jiǎn)單的動(dòng)畫(huà)效果實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- js定時(shí)器實(shí)現(xiàn)倒計(jì)時(shí)效果
- JavaScript定時(shí)器詳解及實(shí)例
- JavaScript暫停和繼續(xù)定時(shí)器的實(shí)現(xiàn)方法
- JavaScript 定時(shí)器 SetTimeout之定時(shí)刷新窗口和關(guān)閉窗口(代碼超簡(jiǎn)單)
- JavaScript定時(shí)器setTimeout()和setInterval()詳解
- Javascript 定時(shí)器調(diào)用傳遞參數(shù)的方法
- js 定時(shí)器setTimeout無(wú)法調(diào)用局部變量的解決辦法
- JS動(dòng)畫(huà)定時(shí)器知識(shí)總結(jié)
- js 遞歸和定時(shí)器的實(shí)例解析
- JavaScript定時(shí)器設(shè)置、使用與倒計(jì)時(shí)案例詳解
相關(guān)文章
關(guān)于獲取DIV內(nèi)部?jī)?nèi)容報(bào)錯(cuò)的原因分析及解決辦法
這篇文章主要介紹了關(guān)于獲取DIV內(nèi)部?jī)?nèi)容報(bào)錯(cuò)的原因分析及解決辦法的相關(guān)資料,需要的朋友可以參考下2016-01-01詳解基于javascript實(shí)現(xiàn)的蘋(píng)果系統(tǒng)底部菜單
本篇文章主要對(duì)基于javascript實(shí)現(xiàn)的蘋(píng)果系統(tǒng)底部菜單進(jìn)行了詳細(xì)的分析說(shuō)明,有助于理解和學(xué)習(xí)編寫(xiě)蘋(píng)果系統(tǒng)底部菜單,相信會(huì)對(duì)大家有所幫助,下面就跟小編一起來(lái)看看吧2016-12-12uniapp實(shí)現(xiàn)人臉識(shí)別功能詳細(xì)示例
這次使用uni-app框架開(kāi)發(fā)一個(gè)小程序,有一個(gè)刷臉功能,所以下面這篇文章主要給大家介紹了關(guān)于uniapp實(shí)現(xiàn)人臉識(shí)別功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-10-10微信小程序ReferenceError:xxx?is?not?defined報(bào)錯(cuò)解決辦法
最近在學(xué)習(xí)微信小程序的開(kāi)發(fā),在一個(gè)練手項(xiàng)目中竟然報(bào)錯(cuò),所以下面這篇文章主要給大家介紹了關(guān)于微信小程序ReferenceError:xxx?is?not?defined報(bào)錯(cuò)的解決辦法,需要的朋友可以參考下2023-12-12點(diǎn)擊按鈕彈出模態(tài)框的一系列操作代碼實(shí)例
這篇文章主要介紹了js彈出模態(tài)框方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03微信小程序開(kāi)發(fā)之map地圖實(shí)現(xiàn)教程
相信大家現(xiàn)在都知道微信小程序吧,下面這篇文章主要給大家介紹了微信小程序開(kāi)發(fā)之map地圖的相關(guān)資料,分享出來(lái)供大家參考學(xué)習(xí),文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-06-06JS項(xiàng)目中對(duì)本地存儲(chǔ)進(jìn)行二次的封裝的實(shí)現(xiàn)
這篇文章主要介紹了JS項(xiàng)目中對(duì)本地存儲(chǔ)進(jìn)行二次的封裝,這里我們將要使用到的key存儲(chǔ)下來(lái),新建一個(gè)叫constant-storage.js的文件,對(duì)外暴露一些key的鍵名,也方便后期統(tǒng)一修改,這里因?yàn)槎际呛懔浚悦Q我們都用大寫(xiě)表示,需要的朋友可以參考下2022-07-07jQuery 表單驗(yàn)證插件formValidation實(shí)現(xiàn)個(gè)性化錯(cuò)誤提示
這里介紹另外一個(gè)表單驗(yàn)證插件formValidation,這個(gè)插件與前面兩個(gè)插件的最大區(qū)別在于它實(shí)現(xiàn)了個(gè)性化的錯(cuò)誤提示信息,顯示在表單元素右上角類似于提示條2009-06-06javascript實(shí)現(xiàn)頁(yè)面滾屏效果
本文主要介紹了javascript實(shí)現(xiàn)頁(yè)面滾屏效果的方法,具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01