用requestAnimationFrame實(shí)現(xiàn)的一個(gè)動(dòng)畫(huà)效果
在看Scott老师的node视频中,讲到一个动画效果,我用requestAnimationFrame实现了这个效果。
代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>应用requestAnimationFrame做一个动画效果</title>
<style type="text/css">
.ball{
width: 20px;
height: 20px;
border-radius: 50%;
}
.red{
background-color: red;
}
.green{
background-color: green;
}
.blue{
background-color: blue;
}
</style>
</head>
<body>
<p>在看node教程,老师介绍promise时,用seTtimeout实现了一个动画效果,用requestAnimationFrame练练手</p>
<div>
<p class="ball red" style="margin-left:0px;"></p>
<p class="ball green" style="margin-left:0px;"></p>
<p class="ball blue" style="margin-left:0px;"></p>
</div>
<script type="text/javascript">
var red = document.querySelector(".red");
var green = document.querySelector(".green");
var blue = document.querySelector(".blue");
window.requestAnimationFrame = window.requestAnimationFrame window.mozRequestAnimationFrame window.webkitRequestAnimationFrame window.msRequestAnimationFrame;
ani(red,100,function(){
ani(green,200,function(){
ani(blue,150,function(){
ani(red,150);
ani(green,150)
})
})
})
function ani(node,to,callback){
var marginLeft = parseInt(node.style.marginLeft);
requestAnimationFrame(function(){
if (marginLeft == to) {
callback && callback()
}else{
if (marginLeft < to) {
marginLeft++
}else if(marginLeft>to){
marginLeft--
}
node.style.marginLeft = marginLeft + "px";
ani(node,to,callback)
}
})
}
</script>
</body>
</html>
點(diǎn)擊查看更多內(nèi)容
2人點(diǎn)贊
評(píng)論
評(píng)論
共同學(xué)習(xí),寫(xiě)下你的評(píng)論
評(píng)論加載中...
作者其他優(yōu)質(zhì)文章
正在加載中
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶(hù)
支付方式
打開(kāi)微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得
100積分直接送
付費(fèi)專(zhuān)欄免費(fèi)學(xué)
大額優(yōu)惠券免費(fèi)領(lǐng)