實(shí)現(xiàn)動(dòng)畫(huà)效果核心方式的js代碼
第一步:實(shí)現(xiàn)一個(gè)匿名函數(shù)并能自己執(zhí)行。
(function(){ })()
這個(gè)函數(shù)在一樣編的好的JS代碼中經(jīng)常會(huì)見(jiàn)到,起到閉包,自動(dòng)執(zhí)行的效果,在函數(shù)后加一對(duì)()表示自動(dòng)執(zhí)行,前邊的匿名函數(shù)需要用()包起來(lái),這樣才能為宿主(我們的BOM環(huán)境)理解,里面的function(){}這就是個(gè)匿名函數(shù)。
第二步:實(shí)現(xiàn)動(dòng)畫(huà),以改變一個(gè)box的秀明度來(lái)說(shuō)明。
id為animation的div
<div id="animation"></div>
要實(shí)現(xiàn)animation的透明漸變,需要不斷改變其透明度opacity,我們這樣實(shí)現(xiàn)
for(var i=0;i<10;i++){
setTimeout((function(pos){
return function(){
someAnimation(pos);
}
})(i/10),i*100)
}
下面我們來(lái)解釋一下這段代碼,這段代碼比較復(fù)雜和難于理解,所以剛開(kāi)始不明白也沒(méi)事,慢慢就懂了,首先解釋一下setTimeout在此處的用法
setTimeout((function(){})(i/10),i*100)
setTimeout第一個(gè)參數(shù)為要執(zhí)行的函數(shù),第二個(gè)參數(shù)為時(shí)間參數(shù),意為多久后開(kāi)始執(zhí)行
而js沒(méi)有塊的概念,作用域范圍是以函數(shù)為準(zhǔn)的,所以我們這里使用的閉包,實(shí)現(xiàn)原理如下:
(function(){
return function(){}
})()
這校才可以執(zhí)行for循環(huán),達(dá)到我們想要的結(jié)果,如果我們不使用閉包,代碼會(huì)如下:
for(var i=0;i<10;i++){
setTimeout(function(pos){
someAnimation(pos);
}(i/10),i*100)
}
這樣的for循環(huán)只會(huì)執(zhí)行一次,即i=9時(shí),感興趣的同學(xué)可以自己試試
到目前為止,整個(gè)代碼是這個(gè)樣子滴
(function(){
function someAnimation(args){
document.getElementById("animation").style.opacity=args;
}
for(var i=0;i<10;i++){
setTimeout((function(pos){
return function(){
someAnimation(pos);
}
})(i/10),i*100)
}
})()
這樣實(shí)現(xiàn)了id為animation的box透明度從0到1的一次變化。
第三步,實(shí)現(xiàn)不停地變化,我們用setInterval來(lái)實(shí)現(xiàn)
setInterval也是兩個(gè)參數(shù),第一個(gè)是要執(zhí)行的函數(shù),第二個(gè)是執(zhí)行間隔時(shí)間
至此代碼如下:
(function(){
function someAnimation(args){
document.getElementById("animation").style.opacity=args;
}
setInterval(function(){
for(var i=0;i<10;i++){
setTimeout((function(pos){
return function(){
someAnimation(pos);
}
})(i/10),i*100)
}
},2000);
})()
下次我會(huì)實(shí)現(xiàn)這個(gè)代碼的面向?qū)ο蠡O(shè)計(jì)和出一些具體的實(shí)現(xiàn)方案,方便學(xué)習(xí)使用。
全部代碼如下
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<title></title>
<style type="text/css">
#animation{width:500px;height:350px;background-color:red;}
</style>
</head>
<body>
<div id="animation">
</div>
<script type="text/javascript">
(function(){
function someAnimation(args){
document.getElementById("animation").style.opacity=args;
}
setInterval(function(){
for(var i=0;i<10;i++){
setTimeout((function(pos){
return function(){
someAnimation(pos);
}
})(i/10),i*100)
}
},2000);
})()
</script>
</body>
</html>
- 又一款js時(shí)鐘!transform實(shí)現(xiàn)時(shí)鐘效果
- 基于css3新屬性transform及原生js實(shí)現(xiàn)鼠標(biāo)拖動(dòng)3d立方體旋轉(zhuǎn)
- 淺談javascript獲取元素transform參數(shù)
- 用js實(shí)現(xiàn)的模擬jquery的animate自定義動(dòng)畫(huà)(2.5K)
- 圖片的左右移動(dòng),js動(dòng)畫(huà)效果實(shí)現(xiàn)代碼
- 九種原生js動(dòng)畫(huà)效果
- javascript判斷css3動(dòng)畫(huà)結(jié)束 css3動(dòng)畫(huà)結(jié)束的回調(diào)函數(shù)
- js動(dòng)畫(huà)(animate)簡(jiǎn)單引擎代碼示例
- JS判斷頁(yè)面加載狀態(tài)以及添加遮罩和緩沖動(dòng)畫(huà)的代碼
- JS實(shí)現(xiàn)超炫網(wǎng)頁(yè)煙花動(dòng)畫(huà)效果的方法
- javascript與css3動(dòng)畫(huà)結(jié)合使用小結(jié)
- js動(dòng)畫(huà)效果打開(kāi)層 關(guān)閉層
- JS實(shí)現(xiàn)動(dòng)畫(huà)兼容性的transition和transform實(shí)例分析
相關(guān)文章
基于css3新屬性transform及原生js實(shí)現(xiàn)鼠標(biāo)拖動(dòng)3d立方體旋轉(zhuǎn)
這篇文章主要介紹了基于css3新屬性transform及原生js實(shí)現(xiàn)鼠標(biāo)拖動(dòng)3d立方體旋轉(zhuǎn) 的相關(guān)資料,需要的朋友可以參考下2016-06-06javascript獲取本機(jī)操作系統(tǒng)類(lèi)型的方法
關(guān)于我們使用電腦的操作系統(tǒng),我們通過(guò)鼠標(biāo)點(diǎn)擊就能獲取,如果我們想用腳本怎么實(shí)現(xiàn)javascript獲取本機(jī)操作系統(tǒng)類(lèi)型的方法呢,下面給大家分享javascript獲取本機(jī)操作系統(tǒng)類(lèi)型的方法,需要的朋友可以參考下2015-08-08lhgcalendar時(shí)間插件限制只能選擇三個(gè)月的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇lhgcalendar時(shí)間插件限制只能選擇三個(gè)月的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07基于JavaScript+HTML5 實(shí)現(xiàn)打地鼠小游戲邏輯流程圖文詳解(附完整代碼)
打地鼠小游戲大家都喜歡玩,本文是以html編寫(xiě)的,并且使用HBulider軟件進(jìn)行編寫(xiě)的,下面通過(guò)本文給大家分享基于JavaScript+HTML5 實(shí)現(xiàn)打地鼠小游戲邏輯流程圖文詳解,需要的朋友參考下吧2017-11-11基于Typescript與Axios的接口請(qǐng)求管理詳解
接口是一系列抽象方法的聲明,是一些方法特征的集合,這些方法都應(yīng)該是抽象的,需要由具體的類(lèi)去實(shí)現(xiàn),然后第三方就可以通過(guò)這組抽象方法調(diào)用,讓具體的類(lèi)執(zhí)行具體的方法,這篇文章主要給大家介紹了基于Typescript與Axios的接口請(qǐng)求管理的相關(guān)資料,需要的朋友可以參考下2021-09-09詳解springmvc 接收json對(duì)象的兩種方式
本篇文章主要介紹了springmvc 接收json對(duì)象的兩種方式,具有一定的參考價(jià)值,有需要的可以了解一下。2016-12-12JavaScript庫(kù)之vanilla-tilt使用教程(一個(gè)平滑的3D傾斜庫(kù))
vanilla-tilt.js是Javascript中一個(gè)平滑的3D傾斜庫(kù),可以讓網(wǎng)頁(yè)的一些控件變得動(dòng)態(tài)起來(lái),下面這篇文章主要給大家介紹了關(guān)于JavaScript庫(kù)之vanilla-tilt使用的相關(guān)資料,需要的朋友可以參考下2023-02-02