自定義拖動進度條,包含樣式和事件

来源:https://www.cnblogs.com/liangzhengxiong/archive/2018/09/15/9650342.html
-Advertisement-
Play Games

自定義可拖動的進度條,如下圖效果: 代碼分三部分 HTML CSS 到這步就基本實現了自定義的樣式,只需改變 .progress-bar 的 width 就能顯示不同的進度;接下來給進度條加上拖動事件 JavaScript 關於本篇隨筆,作者的考慮: 1. 將 mousedown 事件綁定在進度條的 ...


自定義可拖動的進度條,如下圖效果:

代碼分三部分

HTML

 1 <body>
 2     <div id="demo">
 3 
 4         <div class="progress">
 5             <div class="progress-bar">
 6                 <div class="progress-thumb"></div>
 7             </div>
 8         </div>
 9 
10     </div>
11 </body>

CSS

 1 #demo { 
 2     width: 600px; height: 100px; margin: 100px auto; 
 3     display: flex; align-items: center; 
 4 }
 5 
 6 #demo .progress { 
 7     width: 100%; height: 6px; border-radius: 3px; 
 8     background: #F1F5FD; 
 9 }
10 
11 #demo .progress .progress-bar { 
12     width: 40%; height: 100%; border-radius: 3px; 
13     background: #0072FF; 
14 }
15 
16 #demo .progress .progress-bar .progress-thumb { 
17     width: 14px; height: 14px; border-radius: 50%; 
18     background: #FFFFFF; box-shadow: 0 0 15px 5px #0072FF; 
19     float: right; 
20     position: relative; left: 7px; top: -5px; 
21 }

 

到這步就基本實現了自定義的樣式,只需改變 .progress-bar 的 width 就能顯示不同的進度;接下來給進度條加上拖動事件

JavaScript

 1     <script>
 2            
 3         var slider = {
 4             use: function(id) {
 5                 var self = this;
 6                 self.slider = document.getElementById(id);
 7                 self.bar = self.slider.querySelector('.progress-bar');
 8                 self.thumb = self.slider.querySelector('.progress-thumb');
 9                 self.slider.addEventListener('mousedown', function(e) {
10                     if (e.button == 0) { // 判斷點擊左鍵
11                         self.mDown = true;
12                         self.beginX = e.offsetX;
13                         self.positionX = e.offsetX;
14                         self.beginClientX = e.clientX;
15                         self.sliderLong = parseInt(self.getStyle(self.slider, 'width'));
16                         var per = parseInt(self.positionX / self.sliderLong * 100);
17                         self.bar.style.width = per + '%';
18                     }
19                 });
20                 document.addEventListener('mousemove', function(e) {
21                     if (self.mDown) {
22                         var moveX = e.clientX - self.beginClientX;
23                         self.positionX = (self.beginX + moveX > self.sliderLong) ? self.sliderLong : (self.beginX + moveX < 0) ? 0 : self.beginX + moveX;
24                         var per = parseInt(self.positionX / self.sliderLong * 100);
25                         self.bar.style.width = per + '%';
26                     }
27                 });
28                 document.addEventListener('mouseup', function(e) {
29                     if (e.button == 0) { 
30                         self.mDown = false;
31                     }
32                 });
33             },
34             getStyle: function(obj,styleName){ // 獲取元素樣式的方法
35                 if(obj.currentStyle){
36                     return obj.currentStyle[styleName];
37                 }else{
38                     return getComputedStyle(obj,null)[styleName];
39                 }
40             }
41         };
42         slider.use('demo');
43 
44     </script>

關於本篇隨筆,作者的考慮:

  1. 將 mousedown 事件綁定在進度條的包裹層而非進度條本身,這是參考了主流視頻播放器的效果後的設計,為了優化用戶體驗;

  2. JS 用純原生語法書寫,如果用 JQuery 可以簡化選擇器和 CSS 樣式的獲取;

  3. 滑鼠在滾動條外的移動,本文使用 clientX 來計算,如果有其他想法歡迎留言探討

 


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

-Advertisement-
Play Games
更多相關文章
  • 這是第一次使用html寫一個簡單的註冊表 <!DOCTYPE html><html><head> <title>木木音樂網第一次註冊表</title></head><body><h2>使用手機號碼註冊</h2><form action="" method="get"> <p>手機號碼: <input ...
  • 今天在使用scroll-view組件的時候發現結果跟預想的不一樣。其實也不是第一次用了,同樣的寫法卻出現了意料之外的效果,所以認定是bug了。博主使用的是2.3.0版本,所以之前的版本應該也會有這個bug。 ...
  • React 組件中處理 onClick 類似事件綁定的時候,是需要顯式給處理器綁定上下文(context)的,這一度使代碼變得冗餘和難看。 請看如下的示例: class App extends Component { constructor() { super(); this.state = { i ...
  • 今天給大家分享的案例是酷炫的3D照片牆 這個案例主要是通過 CSS3 和原生的 JS 來實現的,接下來我給大家分享一下這個效果實現的過程。博客上不知道怎麼放本地視頻,所以只能放兩張效果截圖了. 1.實現靜態的散開的效果圖 1 <div id="perspective"> 2 <div id="wra ...
  • js中對象可以轉化成 字元串、數字、布爾值 一、對象轉化成字元串: 規則: 1、如果對象有toString方法,則調用該方法,並返回相應的結果;(代碼通常會執行到這,因為在所有對象中都有toString方法) 2、如果對象有valueOf方法,則調用該方法,並返回相應的結果; 3、否則拋出異常。 通 ...
  • 最近因為的工作的原因在弄vue,從後端弄到前端之前一直用js,現在第一次接觸vue感覺還挺有意思的,就是自己太菜了,這個腦子呀。。。。不太夠用。。。。。頁面設計用了一個叫vux的東西,vux可以提供一些組件,用起來還是比較方便的,因為自己比較菜吧,所以有很多東西還是不太深入瞭解。。。比如對vux自帶 ...
  • 服務端的學習 Apache2.4.34 的安裝及配置 1.基本安裝 最新的 Apache 已經不提供 Windows 的安裝版本,所以我們這裡使用的是解壓版 -下載地址:https://www.apachelounge.com/download/ -使用說明:https://httpd.apache ...
  • 今天我們繼續來介紹 Javascirpt 數組中的方法,也是數組系列的第四篇文章,因為數組的方法眾多,每篇文章我們都對數組的每個方法都有比較細緻的描述,只要你能夠從中成長一點點,那我們的目的就達到了,學習是一個持續的,漸進的過程。每天進步一點點,最終會有大成就。 直接進入主題 數組的轉換 我們在項目 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...