在開發網頁或應用程式時,步驟條是一個非常重要的元素,它可以幫助使用者清楚地了解當前進度,以及還有多少工作要完成。通常,一個步驟條應該顯示使用者已經完成的步驟數以及未完成的步驟數,並且需要精確地顯示當前進度百分比。在本文中,我們將介紹如何使用JavaScript顯示一個帶有百分比的步驟條。
步驟一:HTML結構
首先,我們需要在HTML中建立一個步驟條的骨架。我們可以使用一個簡單的無序號表(ul)和一些有序號的清單項目(li),如下所示:
- 1 步骤一
- 2 步骤二
- 3 步骤三
- 4 步骤四
我們可以看到,每個清單項目都包含一個步驟號(由<span class="step"></span>
元素表示)和一個標題(由<span class="title"></span>
元素表示)。在第一個清單項目中,我們也使用了active
類別來表示目前步驟。
步驟二:CSS樣式
接下來,我們需要在CSS中為步驟條定義樣式。我們將使用flexbox來對齊和佈局清單項,如下所示:
.progress { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; list-style: none; } .progress li { flex: 1; text-align: center; position: relative; z-index: 1; } .progress li.active::before { content: ''; position: absolute; top: 50%; left: -50%; width: 200%; height: 4px; background-color: #4caf50; transform: translateY(-50%); z-index: -1; } .progress .step { display: block; width: 30px; height: 30px; line-height: 30px; border-radius: 50%; background-color: #f2f2f2; color: #999; margin-bottom: 10px; } .progress li.active .step { background-color: #4caf50; color: #fff; } .progress .title { display: block; font-size: 12px; color: #777; text-transform: uppercase; margin-bottom: 5px; } .progress li:first-child .title { text-align: left; } .progress li:last-child .title { text-align: right; }
在這個CSS樣式中,我們使用了flexbox來將每個清單項目垂直對齊,並使用justify-content: space-between
讓每個清單項目之間留有一些空間。我們也使用偽元素::before
和position: absolute
將目前步驟背景顏色和百分比進度條呈現出來。注意,我們還為每個清單項目中的步驟號碼和標題添加了相應的樣式。
步驟三:JavaScript程式碼
最後,我們需要寫一些JavaScript程式碼來計算進度百分比,並在步驟列中顯示它。對於每個清單項,我們分別計算已完成的步驟數和總步驟數,然後將進度的百分比顯示在步驟編號旁的元素中。我們可以使用以下程式碼來實現這一點:
// 获取步骤条的UL元素 const progress = document.querySelector('.progress'); // 获取步骤条中的所有列表项 const steps = progress.querySelectorAll('li'); // 遍历每个列表项 steps.forEach((step, index) => { // 获取当前列表项的步骤号 const stepNumber = step.querySelector('.step'); // 计算已完成的步骤数和总步骤数 const completed = index; const total = steps.length - 1; // 计算进度的百分比 const percent = Math.round((completed / total) * 100); // 在步骤号旁边的元素中显示百分比 stepNumber.innerHTML = `${percent}%`; });
注意,我們在這段程式碼中使用了Math.round()
函數來將計算出的進度百分比四捨五入到整數,從而避免小數位誤差所導致的顯示問題。
最後,我們可以將上述這些程式碼儲存到我們的HTML檔案中,並開啟該檔案以查看步驟條及其百分比進度的效果。是不是很簡單?透過上述這些步驟,我們就可以輕鬆地建立一個帶有百分比進度的步驟條,並使使用者清晰地了解他們當前的進度。
以上是javascript步驟條顯示百分比怎麼實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文討論了React中的使用效應,這是一種用於管理副作用的鉤子,例如數據獲取和功能組件中的DOM操縱。它解釋了用法,常見的副作用和清理,以防止記憶洩漏等問題。

JavaScript中的高階功能通過抽象,常見模式和優化技術增強代碼簡潔性,可重複性,模塊化和性能。

本文討論了JavaScript中的咖哩,這是一種將多重題材函數轉換為單詞彙函數序列的技術。它探討了咖哩的實施,諸如部分應用和實際用途之類的好處,增強代碼閱讀

本文解釋了React中的UseContext,該文章通過避免道具鑽探簡化了狀態管理。它討論了通過減少的重新租賃者進行集中國家和績效改善之類的好處。

文章討論了使用DestrestDefault()方法在事件處理程序中預防默認行為,其好處(例如增強的用戶體驗)以及諸如可訪問性問題之類的潛在問題。

本文討論了React中受控和不受控制的組件的優勢和缺點,重點是可預測性,性能和用例等方面。它建議在選擇之間選擇因素。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),