JS---封裝緩動(變速)動畫函數---增加任意一個屬性

来源:https://www.cnblogs.com/jane-panyiyun/archive/2019/12/20/12071428.html
-Advertisement-
Play Games

封裝緩動(變速)動畫 增加任意一個屬性 1. 本來的變速動畫函數,是獲取特定的屬性(之前案例是向右移動,所以獲取的是left屬性) 2. 現在改變為,獲取任意一個屬性,使其移動到指定的target,相當於在原animate(element,target)函數上,增加了一個屬性,變為animate(e ...


封裝緩動(變速)動畫---增加任意一個屬性

 

1. 本來的變速動畫函數,是獲取特定的屬性(之前案例是向右移動,所以獲取的是left屬性)

2. 現在改變為,獲取任意一個屬性,使其移動到指定的target,相當於在原animate(element,target)函數上,增加了一個屬性,變為animate(element, attr, target)函數

3. 改動一:在獲取當前元素的位置,var current,用getStyle來獲取,因為得到的是字元串類型,包一個parseInt改為數字類型;

4. 改動二:移動步數時候,元素的當前位置等於current+"px",element.style.left更新為element.style[attr], 特定的元素用任意元素取代

 

獲得的效果:就是可以使任意元素的,任意一個樣式屬性,移動到指定的目標位置

attr位置,可以改為left,可以改為heigth, 可以改為top,可以改為bgc....等等

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>title</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }

    div {
      margin-top: 20px;
      width: 200px;
      height: 100px;
      background-color: green;
      position: absolute;
      left: 0;
      top: 0;
    }
  </style>
</head>

<body>
  <input type="button" value="移動到400px" id="btn1" />
  <input type="button" value="移動到800px" id="btn2" />
  <div id="dv">
    <script src="common.js"></script>
    <script>
      //點擊按鈕移動div

      my$("btn1").onclick = function () {
        //獲取div此時left的當前位置,達到目標400
        // animate(my$("dv"),"left",400);
        //獲取div此時的寬度,達到目標200
        animate(my$("dv"), "width", 200);
      };

      //獲取任意的一個屬性的當前的屬性值: 改用之前封裝的getStyle函數
      function getStyle(element, attr) {
        //判斷瀏覽器是否支持這個方法
        return window.getComputedStyle ? window.getComputedStyle(element, null)[attr] : element.currentStyle[attr];
      }

      //勻速動畫

      //element---元素
      //attr---屬性名字
      //target---目標位置
      function animate(element, attr, target) {
        //清理定時器
        clearInterval(element.timeId);
        element.timeId = setInterval(function () {
          //獲取元素的當前位置
          var current = parseInt(getStyle(element, attr));//數字類型//===============================
          //移動的步數
          var step = (target - current) / 10;
          step = step > 0 ? Math.ceil(step) : Math.floor(step);
          current += step;
          element.style[attr] = current + "px";//============================================
          if (current == target) {
            //清理定時器
            clearInterval(element.timeId);
          }
          //測試代碼:
          console.log("目標位置:" + target + ",當前位置:" + current + ",每次移動步數:" + step);
        }, 20);
      }
    </script>
  </div>
</body>

</html>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 封裝緩動(變速)動畫函數 增加任意多個屬性&增加回調函數 回掉函數fn,在所有元素到達目的位置後,判斷是否傳入一個函數,有就調用 if(fn){fn()}; 這樣一次點擊,產生多個動畫 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
  • 藉助React,我們可以構建動態且高度交互的單頁應用程式,充分利用這種交互性的一種方法是通過條件渲染。 ...
  • 封裝緩動動畫函數 增加多個任意多個屬性 在原來緩動動畫函數,增加任意一個屬性的基礎上,做瞭如下改變 1. 原來function animate(element, attr, target),三個變數,改為用json對象來裝一對:屬性:目標位置的值,變為function animate(element ...
  • 這篇文章會為一個總結,一個大綱.我會在上面列舉一些前端該學習的東西. 1:面試之道 2:瀏覽器 3:網路協議 4:設計模式 5:工程化 6:性能優化 7:前端安全 8:自動化測試 9:工具調試 10:演算法與數據結構 11:小程式 12:微信公眾號 13:HTML 14:CSS 15:ECMScrip ...
  • JSON 是存儲和傳輸數據的格式。 JSON 經常在數據從伺服器發送到網頁時使用。 什麼是 JSON? JSON 指的是 JavaScript Object Notation JSON 是輕量級的數據交換格式 JSON 獨立於語言 * JSON 是“自描述的”且易於理解 * JSON 的語法是來自 ...
  • legend的data與series的name 兩者必須同時存在,且數量和文字內容必須一致。 ...
  • 公司目前有很多後臺管理系統,目前代碼量都越來越大,在開發的過程中,我們也秉承著提取公共組件,通過復用組件來減少開發工作量,隨著公共組件數量的增加,新同事想要快速瞭解公共組件如何使用,需要到具體的業務頁面中去看,這樣子學習組件的成本太大,於是就想給每個組件提供一個文檔,來解釋組件如何使用。 恰巧之前有 ...
  • 本文由葡萄城技術團隊翻譯並首發 轉載請註明出處:葡萄城官網,葡萄城為開發者提供專業的開發工具、解決方案和服務,賦能開發者。 JavaScript每天都在出現大量的框架和工具,而React是除了上次我們提到的Vue和Ember之外另一款比較流行的框架。但因為新的工具每天都在不斷的出現,開發者在嘗試時總 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...