亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS運動特效之完美運動框架實例分析

2019-11-19 14:29:00
字體:
來源:轉載
供稿:網友

本文實例講述了JS運動特效之運動框架。分享給大家供大家參考,具體如下:

在前面一篇的《js運動特效之同時運動》中說過,我們的運動框架還存在一個問題,那究竟是什么問題那?把上一篇的程序做一下調整

oDiv.onmouseover = function () {   //startMove(oDiv,{width:300,height:300,opacity:30});   startMove(oDiv,{width:204,height:300,opacity:30});}

在鼠標移入的時候,我們讓width不變成300,而是變成204,看看會有什么變化那??

從圖可以看出,當鼠標移入的時候,只有寬度達到了預期的值204,而height和opacity都沒有達到目標值(目標值是300和0.3),這是為什么那??是下面的問題引起的

if(objAttr == json[attr]){    clearInterval(obj.timer);    if(fn){      fn();    }}

if語句里只是判斷當objAttr 等于目標值的時候就清除定時器(也就是說只要有一個屬性到達目標值就進入if,清除定時器),并不是判斷“所有的運動”都達到了目標值;width從200變成204很快就達到目標值了,而此時height和opacity還在半路上;但是由于width已經達到了目標值,所以就進入if語句清除了定時器,width,height,opacity它們用的是一個定時器,所以此時height和opacity就定格在半道上永遠無法達到目標值了。

那怎么解決那???

1. 在進入定時器的時候,設置一個標志位var flag ,用它來檢測是否所有的運動都到達目標值

function startMove(obj,json,fn) {      clearInterval(obj.timer);      obj.timer = setInterval(function () {       var flag = true;// 一進入定時器設置標志位      },30);}var flag = true;// 表示所有的運動都到達目標值var flag = false;// 表示有的運動沒有到達目標值

2 . 接著在檢測運動是否停止的語句中做判斷

if(objAttr != json[attr]){// 判斷是否所有的運動都達到目標值     // 進入if語句,說明至少有一個 運動未到達目標值     flag = false;}

for...in.循環里面每一個屬性做變化(widht,height,opacity...),只要有一個屬性變化沒有到達目標值,flag標志的值就是false;然后在整個for...in..循環之外判斷flag的值,如果依然為true就標志“所有的運動”都到達了目標值,此時就可以清除定時器了

for(attr in json){}if(flag){// 再次判斷flag的值  clearInterval(obj.timer);  if(fn){    fn();  }}

定時器每隔30毫秒執行一次,每次進入首先設置var flag =true ,然后向下執行,每一回都要判斷

if(objAttr != json[attr]){ ... }只要有一個運動沒有達到目標值,都會進入執行if語句,把flag設為false,當定時器最后一次執行的時候,發現所有的屬性都到達了目標值,此時if語句就不成立了,就沒機會把flag設為flase了,所以最后一次進入定時器flag的始終是true;接著就滿足了if(flag){  ...  }的條件,接著進入if(flag){  ...  }執行。

到這里就完美了,看下效果

完整測試代碼:

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. 取得當前的值(可以是widht,height,opacity等的值)          var objAttr = 0;          if(attr == "opacity"){            objAttr = Math.round(parseFloat(getStyle(obj,attr))*100);          }else{            objAttr = parseInt(getStyle(obj,attr));          }          // 2.計算運動速度          var iSpeed = (json[attr] -objAttr)/10;            iSpeed = iSpeed>0 ?Math.ceil(iSpeed):Math.floor(iSpeed);          // 3. 檢測所有運動是否到達目標          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){ // 表示所有運動都到達目標值          clearInterval(obj.timer);          if(fn){            fn();          }        }      },30);    }</script>

到這里我們就可以把這個運動框架單獨出來,保存成js文件供我們以后享用了!

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《JavaScript運動效果與技巧匯總》、《JavaScript切換特效與技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript動畫特效與技巧匯總》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产乱码久久久久久久久| 综合国产在线视频| 国产一区二区三区高清在线观看| 色婷婷成人综合| 亚洲精品乱码久久久久久金桔影视| 日本一区二区在线免费播放| 一本色道久久88精品综合| 欧美片一区二区三区| 青青草99啪国产免费| 热re99久久精品国产66热| 青青草一区二区| 精品色蜜蜜精品视频在线观看| 精品国产乱码久久久久久虫虫漫画| 国产精品网站视频| 精品久久久国产| 亚洲天堂av在线免费| 国产亚洲精品va在线观看| 91久久在线播放| 91精品国产综合久久香蕉922| 国产精品一香蕉国产线看观看| 一夜七次郎国产精品亚洲| 亚洲国产97在线精品一区| 成人乱人伦精品视频在线观看| 久久电影一区二区| 久久久亚洲精选| 91精品国产综合久久男男| 国内精品久久久久伊人av| 在线午夜精品自拍| 亚洲最新中文字幕| 欧美日韩在线视频观看| 亚洲精品国产电影| 国产精品wwwwww| 欧美日韩午夜激情| 亚洲视频在线观看视频| 日韩欧美大尺度| 欧美最顶级丰满的aⅴ艳星| 一本色道久久88精品综合| 中文字幕一区二区精品| 粗暴蹂躏中文一区二区三区| 亚洲成**性毛茸茸| 亚洲精品午夜精品| 日韩av在线直播| 日韩成人av网址| 91免费看片网站| 色偷偷88888欧美精品久久久| 91精品视频一区| 国产一区玩具在线观看| 一二美女精品欧洲| 丝袜美腿精品国产二区| 国产精品免费一区二区三区都可以| 日韩一级裸体免费视频| 91tv亚洲精品香蕉国产一区7ujn| 日韩av手机在线观看| 欧美在线亚洲在线| 日韩av影院在线观看| 国内精品一区二区三区四区| 国产一区红桃视频| 日韩av在线高清| 国产福利精品av综合导导航| 久久久国产精彩视频美女艺术照福利| 国产综合福利在线| 国产区精品视频| 懂色av一区二区三区| 亚洲一区二区久久久久久久| 亚洲视频在线观看网站| 欧美精品videossex性护士| 55夜色66夜色国产精品视频| 欧美成人精品一区二区| 欧美日韩亚洲91| 亚洲精品成人网| 欧美一区二区视频97| 日韩欧美一区二区在线| 91精品一区二区| 九九精品在线观看| 亚洲国产精品va在线看黑人动漫| 国产精品99久久久久久人| 45www国产精品网站| 日韩成人在线网站| 国产精品一区二区三区成人| 91精品视频大全| 青青久久aⅴ北条麻妃| 神马国产精品影院av| 精品香蕉一区二区三区| 国产精品大片wwwwww| 亚洲精品国产精品国自产在线| 欧美亚洲国产日韩2020| 久久影视电视剧免费网站| 国产99久久精品一区二区永久免费| 欧美激情亚洲综合一区| 亚洲片在线资源| 91色在线视频| 欧美日韩成人在线观看| 亚洲影院高清在线| 555www成人网| 色综合色综合久久综合频道88| 久久精品人人做人人爽| 欧美最顶级丰满的aⅴ艳星| 国产99久久精品一区二区| 正在播放欧美视频| 久久人人爽人人爽人人片亚洲| 精品毛片三在线观看| 欧美在线视频免费观看| 尤物99国产成人精品视频| 日韩天堂在线视频| 97精品久久久| 日韩女优人人人人射在线视频| 亚洲女人天堂视频| 国产精品女视频| 欧美午夜激情在线| 久久精品视频亚洲| 欧美怡春院一区二区三区| 久久综合久久88| 亚洲乱亚洲乱妇无码| 日韩成人av在线播放| 精品久久久久久亚洲国产300| 成人在线激情视频| 成人写真福利网| 亚洲最大福利网| 亚洲日本中文字幕免费在线不卡| 97色在线观看| 欧美大片在线看| 96pao国产成视频永久免费| 亚洲精品mp4| 色偷偷偷综合中文字幕;dd| 国产精品嫩草影院一区二区| 久久久人成影片一区二区三区观看| 亚洲国产精品福利| 国产男人精品视频| 一区二区三区精品99久久| 色悠悠久久88| 亚洲男人的天堂在线播放| 最近2019免费中文字幕视频三| 性欧美办公室18xxxxhd| 精品久久香蕉国产线看观看亚洲| 欧美精品videofree1080p| 中文字幕av一区二区| 国产精品一区二区久久国产| 亚州av一区二区| 国产福利视频一区二区| 久久亚洲精品小早川怜子66| 亚洲国产美女精品久久久久∴| 久久久久久久av| 日韩免费在线免费观看| 欧美亚洲在线观看| 欧美电影免费观看电视剧大全| 日韩免费高清在线观看| 日韩高清有码在线| 久久久亚洲欧洲日产国码aⅴ| 中文国产亚洲喷潮| 8x海外华人永久免费日韩内陆视频| 成人精品视频99在线观看免费| 97成人精品视频在线观看| 亚洲精品99久久久久中文字幕| 亚洲91av视频| 亚洲黄色av女优在线观看| 亚洲www永久成人夜色| 精品成人69xx.xyz| 九九精品在线播放| 日韩电影免费在线观看| 狠狠躁夜夜躁人人爽超碰91| 亚洲xxxx18| 国产欧亚日韩视频| 亚洲肉体裸体xxxx137| 国产综合在线观看视频|