使用 html css js 的流程
程式碼
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>Process Flow</title> <style> body { display: flex; justify-content: center; align-items: center; flex-direction: column; height: 100vh; background-color: #121212; /* Dark background */ margin: 0; color: #ffffff; /* White text for better visibility */ font-family: Arial, sans-serif; } .process-container { display: flex; align-items: center; position: relative; width: 100%; max-width: 800px; } .phase { flex: 1; text-align: center; position: relative; z-index: 1; } .phase-line { position: absolute; top: 50%; left:40%; width: 130%; height: 4px; /* Line thickness */ background-color: #ccc; /* Light gray line */ z-index: 0; } .phase-line.active { background-color: #007bff; /* Active blue line */ } .phase-circle { width: 30px; height: 30px; background-color: #fff; /* Default white circle */ border-radius: 50%; display: inline-block; transition: background-color 0.3s; z-index: 1; line-height: 30px; /* Center the number vertically */ font-weight: bold; /* Make the number bold */ color: #000; /* Black text for better visibility */ } .phase-circle.active { background-color: #007bff; /* Active blue circle */ color: #fff; /* White text when active */ } button { padding: 10px 20px; font-size: 1.2rem; background-color: #007bff; color: white; border: none; border-radius: 5px; cursor: pointer; margin: 10px; transition: background-color 0.3s; } button:hover { background-color: #0056b3; } p{ font-weight: 400; font-size: smaller; } </style> </head> <body> <div class="process-container"> <div class="phase"> <div class="phase-circle active" id="phase1">1</div> <div class="phase-line active" id="line1"></div> <p>About You</p> </div> <div class="phase"> <div class="phase-circle" id="phase2">2</div> <div class="phase-line" id="line2"></div> <p>About Book</p> </div> <div class="phase"> <div class="phase-circle" id="phase3">3</div> <div class="phase-line" id="line3"></div> <p>Review</p> </div> <div class="phase"> <div class="phase-circle" id="phase4">4</div> <div class="phase-line" id="line4"></div> <p>Buy</p> </div> <div class="phase"> <div class="phase-circle" id="phase5">5</div> <p>Finish</p> </div> </div> <div> <button id="prevButton">Previous</button> <button id="nextButton">Next</button> </div> <script> let currentPhase = 1; const updatePhase = () => { for (let i = 1; i <= 5; i++) { const phaseCircle = document.getElementById(`phase${i}`); const phaseLine = document.getElementById(`line${i}`); if (i < currentPhase) { phaseCircle.classList.add('active'); if (phaseLine) phaseLine.classList.add('active'); } else if (i === currentPhase) { phaseCircle.classList.add('active'); if (phaseLine) phaseLine.classList.add('active'); } else { phaseCircle.classList.remove('active'); if (phaseLine) phaseLine.classList.remove('active'); } } }; document.getElementById('nextButton').addEventListener('click', () => { if (currentPhase < 5) { currentPhase++; updatePhase(); } }); document.getElementById('prevButton').addEventListener('click', () => { if (currentPhase > 1) { currentPhase--; updatePhase(); } }); updatePhase(); // Initialize the phase display </script> </body> </html>
以上是使用 html css js 的流程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undress AI Tool
免費脫衣圖片

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

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

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在Node.js中發起HTTP請求有三種常用方式:使用內置模塊、axios和node-fetch。 1.使用內置的http/https模塊無需依賴,適合基礎場景,但需手動處理數據拼接和錯誤監聽,例如用https.get()獲取數據或通過.write()發送POST請求;2.axios是基於Promise的第三方庫,語法簡潔且功能強大,支持async/await、自動JSON轉換、攔截器等,推薦用於簡化異步請求操作;3.node-fetch提供類似瀏覽器fetch的風格,基於Promise且語法簡單

JavaScript的數據類型分為原始類型和引用類型。原始類型包括string、number、boolean、null、undefined和symbol,其值不可變且賦值時復制副本,因此互不影響;引用類型如對象、數組和函數存儲的是內存地址,指向同一對象的變量會相互影響。判斷類型可用typeof和instanceof,但需注意typeofnull的歷史問題。理解這兩類差異有助於編寫更穩定可靠的代碼。

JavaScript數組中,除了map和filter,還有其他強大且不常用的方法。 1.reduce不僅能求和,還可計數、分組、展平數組、構建新結構;2.find和findIndex用於查找單個元素或索引;3.some和every用於判斷是否存在或全部滿足條件;4.sort可排序但會改變原數組;5.使用時注意複製數組避免副作用。這些方法使代碼更簡潔高效。

JavaScript中filter()方法用於創建一個包含所有通過測試元素的新數組。 1.filter()不修改原數組,而是返回符合條件元素的新數組;2.基本語法為array.filter((element)=>{returncondition;});3.可按屬性值過濾對像數組,如篩選年齡大於30的用戶;4.支持多條件篩選,例如同時滿足年齡和名字長度條件;5.可處理動態條件,將篩選參數傳入函數以實現靈活過濾;6.使用時注意必須返回布爾值,避免返回空數組,以及結合其他方法實現字符串匹配等複雜邏

在JavaScript中檢查數組是否包含某個值,最常用方法是includes(),它返回布爾值,語法為array.includes(valueToFind),例如fruits.includes('banana')返回true;若需兼容舊環境,則使用indexOf(),如numbers.indexOf(20)!==-1返回true;對於對像或複雜數據,應使用some()方法進行深度比較,如users.some(user=>user.id===1)返回true。

虛擬DOM是一種優化真實DOM更新的編程概念,通過在內存中創建與真實DOM對應的樹形結構,避免頻繁直接操作真實DOM。其核心原理是:1.數據變化時生成新的虛擬DOM;2.對比新舊虛擬DOM找出最小差異;3.批量更新真實DOM以減少重排重繪開銷。此外,使用唯一穩定key可提升列表對比效率,而部分現代框架已採用其他技術替代虛擬DOM。

處理異步函數中的錯誤應使用try/catch、在調用鏈中處理、使用.catch()方法、並監聽unhandledrejection事件。 1.使用try/catch捕獲錯誤是推薦方式,結構清晰且能處理await中的異常;2.在調用鏈中處理錯誤可集中邏輯,適合多步驟流程;3.使用.catch()可在調用async函數後捕獲錯誤,適用於Promise組合場景;4.監聽unhandledrejection事件可記錄未處理的rejection,作為最後一道防線;以上方法共同確保異步錯誤被正確捕獲和處理。

處理JavaScript時區問題的關鍵在於選擇合適的方法。 1.使用原生Date對象時,推薦以UTC時間進行存儲和傳輸,並在展示時轉換為用戶本地時區;2.對於復雜時區操作,可使用moment-timezone,它支持IANA時區數據庫並提供便捷的格式化與轉換功能;3.若需本地化顯示時間且不想引入第三方庫,可使用Intl.DateTimeFormat;4.推薦現代輕量方案day.js配合timezone和utc插件,其API簡潔、性能良好並支持時區轉換。
