JS運(yùn)動(dòng)特效之完美運(yùn)動(dòng)框架實(shí)例分析
本文實(shí)例講述了JS運(yùn)動(dòng)特效之運(yùn)動(dòng)框架。分享給大家供大家參考,具體如下:
在前面一篇的《js運(yùn)動(dòng)特效之同時(shí)運(yùn)動(dòng)》中說過,我們的運(yùn)動(dòng)框架還存在一個(gè)問題,那究竟是什么問題那?把上一篇的程序做一下調(diào)整
oDiv.onmouseover = function () { //startMove(oDiv,{width:300,height:300,opacity:30}); startMove(oDiv,{width:204,height:300,opacity:30}); }
在鼠標(biāo)移入的時(shí)候,我們讓width不變成300,而是變成204,看看會(huì)有什么變化那??
從圖可以看出,當(dāng)鼠標(biāo)移入的時(shí)候,只有寬度達(dá)到了預(yù)期的值204,而height和opacity都沒有達(dá)到目標(biāo)值(目標(biāo)值是300和0.3),這是為什么那??是下面的問題引起的
if(objAttr == json[attr]){ clearInterval(obj.timer); if(fn){ fn(); } }
if語(yǔ)句里只是判斷當(dāng)objAttr 等于目標(biāo)值的時(shí)候就清除定時(shí)器(也就是說只要有一個(gè)屬性到達(dá)目標(biāo)值就進(jìn)入if,清除定時(shí)器),并不是判斷“所有的運(yùn)動(dòng)”都達(dá)到了目標(biāo)值;width從200變成204很快就達(dá)到目標(biāo)值了,而此時(shí)height和opacity還在半路上;但是由于width已經(jīng)達(dá)到了目標(biāo)值,所以就進(jìn)入if語(yǔ)句清除了定時(shí)器,width,height,opacity它們用的是一個(gè)定時(shí)器,所以此時(shí)height和opacity就定格在半道上永遠(yuǎn)無法達(dá)到目標(biāo)值了。
那怎么解決那???
1. 在進(jìn)入定時(shí)器的時(shí)候,設(shè)置一個(gè)標(biāo)志位var flag ,用它來檢測(cè)是否所有的運(yùn)動(dòng)都到達(dá)目標(biāo)值
function startMove(obj,json,fn) { clearInterval(obj.timer); obj.timer = setInterval(function () { var flag = true;// 一進(jìn)入定時(shí)器設(shè)置標(biāo)志位 },30); } var flag = true;// 表示所有的運(yùn)動(dòng)都到達(dá)目標(biāo)值 var flag = false;// 表示有的運(yùn)動(dòng)沒有到達(dá)目標(biāo)值
2 . 接著在檢測(cè)運(yùn)動(dòng)是否停止的語(yǔ)句中做判斷
if(objAttr != json[attr]){// 判斷是否所有的運(yùn)動(dòng)都達(dá)到目標(biāo)值 // 進(jìn)入if語(yǔ)句,說明至少有一個(gè) 運(yùn)動(dòng)未到達(dá)目標(biāo)值 flag = false; }
for...in.循環(huán)里面每一個(gè)屬性做變化(widht,height,opacity...),只要有一個(gè)屬性變化沒有到達(dá)目標(biāo)值,flag標(biāo)志的值就是false;然后在整個(gè)for...in..循環(huán)之外判斷flag的值,如果依然為true就標(biāo)志“所有的運(yùn)動(dòng)”都到達(dá)了目標(biāo)值,此時(shí)就可以清除定時(shí)器了
for(attr in json){ } if(flag){// 再次判斷flag的值 clearInterval(obj.timer); if(fn){ fn(); } }
定時(shí)器每隔30毫秒執(zhí)行一次,每次進(jìn)入首先設(shè)置var flag =true
,然后向下執(zhí)行,每一回都要判斷
if(objAttr != json[attr]){ ... }
只要有一個(gè)運(yùn)動(dòng)沒有達(dá)到目標(biāo)值,都會(huì)進(jìn)入執(zhí)行if語(yǔ)句,把flag設(shè)為false,當(dāng)定時(shí)器最后一次執(zhí)行的時(shí)候,發(fā)現(xiàn)所有的屬性都到達(dá)了目標(biāo)值,此時(shí)if語(yǔ)句就不成立了,就沒機(jī)會(huì)把flag設(shè)為flase了,所以最后一次進(jìn)入定時(shí)器flag的始終是true;接著就滿足了if(flag){ ... }
的條件,接著進(jìn)入if(flag){ ... }
執(zhí)行。
到這里就完美了,看下效果
完整測(cè)試代碼:
Hhtm部分和css部分和上一篇完全一樣。js代碼如下
<script> window.onload = function(){ var oDiv = document.getElementById('div1'); oDiv.onmouseover = function () { //startMove(oDiv,{width:300,height:300,opacity:30}); startMove(oDiv,{width:204,height:300,opacity:30}); } oDiv.onmouseout = function () { startMove(oDiv,{width:200,height:200,opacity:100}); } } function getStyle(obj,attr){ return getComputedStyle ? getComputedStyle(obj,false)[attr] : obj.currentStyle[attr]; } function startMove(obj,json,fn) { clearInterval(obj.timer); obj.timer = setInterval(function () { var bStop = true; for(attr in json){ // 1. 取得當(dāng)前的值(可以是widht,height,opacity等的值) var objAttr = 0; if(attr == "opacity"){ objAttr = Math.round(parseFloat(getStyle(obj,attr))*100); }else{ objAttr = parseInt(getStyle(obj,attr)); } // 2.計(jì)算運(yùn)動(dòng)速度 var iSpeed = (json[attr] -objAttr)/10; iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed); // 3. 檢測(cè)所有運(yùn)動(dòng)是否到達(dá)目標(biāo) if(objAttr != json[attr]){ bStop = false; } if(attr == "opacity"){ obj.style.filter = 'alpha(opacity:'+(objAttr+iSpeed)+')'; obj.style.opacity = (objAttr+iSpeed)/100; }else{ obj.style[attr] = objAttr+iSpeed+'px';// 需要又.屬性名的形式改成[] } } if(bStop){ // 表示所有運(yùn)動(dòng)都到達(dá)目標(biāo)值 clearInterval(obj.timer); if(fn){ fn(); } } },30); } </script>
到這里我們就可以把這個(gè)運(yùn)動(dòng)框架單獨(dú)出來,保存成js文件供我們以后享用了!
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript運(yùn)動(dòng)效果與技巧匯總》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- js實(shí)現(xiàn)緩沖運(yùn)動(dòng)效果的方法
- JS實(shí)現(xiàn)多物體緩沖運(yùn)動(dòng)實(shí)例代碼
- JS多物體實(shí)現(xiàn)緩沖運(yùn)動(dòng)效果示例
- JS實(shí)現(xiàn)物體帶緩沖的間歇運(yùn)動(dòng)效果示例
- javascript 緩沖運(yùn)動(dòng)框架的實(shí)現(xiàn)
- JS實(shí)現(xiàn)的拋物線運(yùn)動(dòng)效果示例
- JS運(yùn)動(dòng)特效之同時(shí)運(yùn)動(dòng)實(shí)現(xiàn)方法分析
- JS運(yùn)動(dòng)特效之任意值添加運(yùn)動(dòng)的方法分析
- JS小球拋物線軌跡運(yùn)動(dòng)的兩種實(shí)現(xiàn)方法詳解
- JS實(shí)現(xiàn)運(yùn)動(dòng)緩沖效果的封裝函數(shù)示例
相關(guān)文章
Javascript實(shí)現(xiàn)漢字和拼音互轉(zhuǎn)的終極方案
網(wǎng)上關(guān)于JS實(shí)現(xiàn)漢字和拼音互轉(zhuǎn)的文章很多,但是比較雜亂,有的不支持多音字、不支持聲調(diào)或者字典文件太大,無法根據(jù)實(shí)際需要滿足需求。這篇文章給大家修正整理網(wǎng)上的幾種常見方法,文章結(jié)尾還附簡(jiǎn)單的JS拼音輸入法,本文對(duì)大家具有一定的參考借鑒價(jià)值,下面一起看看吧。2016-10-10JavaScript通過select動(dòng)態(tài)更換圖片的方法
這篇文章主要介紹了JavaScript通過select動(dòng)態(tài)更換圖片的方法,涉及javascript動(dòng)態(tài)操作圖片src的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03用JavaScript實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了用JavaScript實(shí)現(xiàn)簡(jiǎn)單網(wǎng)頁(yè)時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08JavaScript+Canvas實(shí)現(xiàn)繪制音頻可視化波形圖
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript和Canvas實(shí)現(xiàn)繪制音頻可視化波形圖,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02js實(shí)現(xiàn)從右往左勻速顯示圖片(無縫輪播)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)從右往左勻速顯示圖片,無縫輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06基于JavaScript實(shí)現(xiàn)點(diǎn)擊頁(yè)面任何位置返回
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)點(diǎn)擊頁(yè)面任何位置返回的實(shí)例代碼,需要的朋友可以參考下2016-08-08JavaScript實(shí)現(xiàn)簡(jiǎn)單計(jì)算器小程序
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單計(jì)算器小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01