欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JavaScript運動框架之鏈式運動的示例分析

這篇文章主要介紹了JavaScript運動框架之鏈式運動的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)公司網(wǎng)站建設(shè)公司一直秉承“誠信做人,踏實做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個客戶多一個朋友!專注中小微企業(yè)官網(wǎng)定制,成都網(wǎng)站設(shè)計、網(wǎng)站制作、外貿(mào)營銷網(wǎng)站建設(shè),塑造企業(yè)網(wǎng)絡(luò)形象打造互聯(lián)網(wǎng)企業(yè)效應(yīng)。

鏈式運動就是運動完后接著再運動,比如很多網(wǎng)站中,一個方框的出現(xiàn)和退出:出現(xiàn)時先變寬再變高,退出時先變矮再變窄退出!
之前的模型是:

startMove(obj, json);

現(xiàn)在改為:

startMove(obj, json, fn);

也就是在第一次運動結(jié)束的時候執(zhí)行fn(); fn是傳過來的一個參數(shù),這個參數(shù)是個函數(shù),定時器清理之后手動運行fn();如果想采用鏈式運動,那就是在fn中再調(diào)用startMove(obj, json, fn),再在里面的fn中調(diào)用startMove(obj, json, fn),可以一直玩下去

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>運動框架(五):鏈式運動到完美運動</title>
  <style type="text/css">
    div {
      width: 100px;
      height: 100px;
      background: orange;
      margin: 10px;
      float: left;
    }
  </style>
</head>
<body>
  <div id="div1"></div>

  <script type="text/javascript">
    var oDiv = document.getElementById('div1');
    oDiv.onmouseover = function() {
      startMove(oDiv, {width:300,opacity:30}, function() {
        startMove(oDiv, {height:500});
      });
    };
    oDiv.onmouseout = function() {
      startMove(oDiv, {height:100}, function() {
        startMove(oDiv, {width:100,opacity:100});
      })
    };

    function getStyle(obj, attr) {
      if (obj.currentStyle) {
        return obj.currentStyle[attr];
      } else {
        return getComputedStyle(obj, null)[attr];
      }
    }

    function startMove(obj, json, fn) {
      clearInterval(obj.timer);
      obj.timer = setInterval(function() {
        var bStop = true;
        for (var attr in json) {
          var cur = 0;
          if (attr === 'opacity') {
            cur = Math.round(parseFloat(getStyle(obj, attr)) * 100);
          } else {
            cur = parseInt(getStyle(obj, attr));
          }
          if (cur != json[attr]) {
            bStop = false;
          }
          var speed = (json[attr] - cur)/10;
          speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
          cur += speed;
          if (attr === 'opacity') {
            obj.style.filter = 'alpha(opacity:' + cur + ')';
            obj.style.opacity = cur/100;
          } else {
            obj.style[attr] = cur + 'px';
          }

        }
        if (bStop) {
          clearInterval(obj.timer);
          if (fn) fn();
        }

      }, 30);
    }
  </script>
</body>
</html>

最后提取出來的完美運動框架如下,motionFrame.js:

function getStyle(obj, attr) {
  if (obj.currentStyle) {
    return obj.currentStyle[attr];
  } else {
    return getComputedStyle(obj, null)[attr];
  }
}

function startMove(obj, json, fn) {
  clearInterval(obj.timer);
  obj.timer = setInterval(function() {
    var bStop = true;
    for (var attr in json) {
      var cur = 0;
      if (attr === 'opacity') {
        cur = Math.round(parseFloat(getStyle(obj, attr)) * 100);
      } else {
        cur = parseInt(getStyle(obj, attr));
      }
      if (cur != json[attr]) {
        bStop = false;
      }
      var speed = (json[attr] - cur)/10;
      speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);
      cur += speed;
      if (attr === 'opacity') {
        obj.style.filter = 'alpha(opacity:' + cur + ')';
        obj.style.opacity = cur/100;
      } else {
        obj.style[attr] = cur + 'px';
      }

    }
    if (bStop) {
      clearInterval(obj.timer);
      if (fn) fn();
    }

  }, 30);
}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“JavaScript運動框架之鏈式運動的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

網(wǎng)頁名稱:JavaScript運動框架之鏈式運動的示例分析
分享鏈接:http://aaarwkj.com/article2/gdisoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、網(wǎng)站建設(shè)、標簽優(yōu)化App開發(fā)、ChatGPT網(wǎng)站設(shè)計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

營銷型網(wǎng)站建設(shè)
国产精品一区二区av不卡| 久久一二三四区中文字幕| 四虎永久精品国产毛片| 久久久久亚洲av成人| 少妇毛片一区二区三区| 91日本在线免费观看视频| 在线成人免费日韩视频| 色哟哟网站在线观看入口| 18岁以下禁看视频网站| 国产综合精品一区二区| 国产欧美一区二区三区久久| 亚洲精品国产精品成人| 日本九州不卡久久精品一区| 92午夜福利精品视频| 欧美日韩亚洲中文国产| 国产91一区二区三区在线精品| 熟女av一区二区三区四区| 中文字幕日本专区人妻| 亚洲一区麻豆文化传媒| 国产美女极度色诱视频| 日韩在线一区二区三区电影| 日本在线电影一区二区三区| 欧美伊人色综合久久天天| 91国产香蕉在线观看| 欧美日韩在线一区二区| 国产不卡一区不卡二区| 加勒比东京热视频在线| 国产亚洲精品精品国产亚洲| 青草视频在线播放免费| 欧美中文字幕内射合集| 97成人在线免费视频| 亚洲精品成人久久av| 亚洲欧美综合区丁香六月| 中文字幕乱码在线观看一区| 国产麻豆精品二区视频| 欧美特黄高清在线观看| 亚洲伊人av第一页在线观看| 神马免费午夜福利剧场| 午夜欧美日韩精品久久久| 日本中文字幕一区在线观看 | 亚洲三级伦理在线视频|