使用JS和CSS制作的小案例(day二)

一、寫在開頭

本項目是從github上摘取,自己練習使用后分享,方便登錄github的小伙伴可以看本篇文章

50項目50天?編輯https://github.com/bradtraversy/50projects50daysicon-default.png?t=N7T8https://github.com/bradtraversy/50projects50days有興趣的小伙伴可以自己去github上查看。

二、項目開始

這里展示的進度條效果,鼠標點擊按鈕,進度條開始變化。

對應的,這里我先把代碼貼出,在一點點剖析

html頁面

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><link rel="stylesheet" href="index.css"><title>進度條</title>
</head><body><div class="container"><div class="progress-container"><div class="progress" id="progress"></div><div class="circle active">1</div><div class="circle">2</div><div class="circle">3</div><div class="circle">4</div></div><button class="btn" id="prev" disabled>Prev</button><button class="btn" id="next">Next</button></div><script src="index.js"></script>
</body></html>

css

:root {--line-border-fill: #3498db;--line-border-empty: #383838;}* {box-sizing: border-box;
}body {background-color: #f1f1f1;font-family: 'Muli', sans-serif;display: flex;align-items: center;justify-content: center;height: 100vh;overflow: hidden;margin: 0;
}.container {text-align: center;
}.progress-container {display: flex;justify-content: space-between;position: relative;margin-bottom: 30px;max-width: 100%;width: 350px;
}.progress-container::before {content: '';background-color: var(--line-border-empty);position: absolute;top: 50%;left: 0;transform: translateY(-50%);height: 4px;width: 100%;z-index: -1;
}.progress {background-color: var(--line-border-fill);position: absolute;top: 50%;left: 0;transform: translateY(-50%);height: 4px;width: 0%;z-index: -1;transition: 0.4s ease;
}.circle {background-color: #f1f1f1;color: #e2e2e2;border-radius: 50%;height: 30px;width: 30px;display: flex;align-items: center;justify-content: center;border: 3px solid var(--line-border-empty);transition: 0.4s ease;
}.circle.active {border-color: var(--line-border-fill);
}.btn {background-color: var(--line-border-fill);color: #fff;border: 0;border-radius: 6px;cursor: pointer;font-family: inherit;padding: 8px 30px;margin: 5px;font-size: 14px;
}.btn:active {transform: scale(0.98);
}.btn:focus {outline: 0;
}.btn:disabled {background-color: var(--line-border-empty);cursor: not-allowed;
}

js

const progress = document.getElementById("progress");
const prev = document.getElementById("prev");
const next = document.getElementById("next");
const circles = document.querySelectorAll(".circle");let currentActive = 1;next.addEventListener("click", () => {currentActive++;if (currentActive > circles.length) {currentActive = circles.length;}update();
});prev.addEventListener("click", () => {currentActive--;if (currentActive < 1) {currentActive = 1;}update();
});function update() {circles.forEach((circle, idx) => {if (idx < currentActive) {circle.classList.add("active");} else {circle.classList.remove("active");}})// 更新進度條const actives = document.querySelectorAll(".active")progress.style.width = ((actives.length - 1) / (circles.length - 1)) * 100 + "%";// 做邊界判斷if(currentActive === 1){prev.disabled = true;}else if(currentActive === circles.length){next.disabled = true;}else{prev.disabled = false;next.disabled = false;}}

三、具體解析

html頁面

css

js

四、最后

希望這個案例可以幫助一些剛接觸html、css、JavaScript的小伙伴。學習知識很重要,但是必要的練習是必不可少的。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/45861.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/45861.shtml
英文地址,請注明出處:http://en.pswp.cn/web/45861.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

面向對象七大原則

學習目標 了解面向對象七大原則基本概念。 在之后實踐應用中&#xff0c;要給予七大原則去設計程序。 為什么有七大原則 七大原則總體要實現的目標是&#xff1a; 高內聚、低耦合。 使程序模塊的可重復性、移植性增強。 高內聚低耦合 從類角度來看&#xff0c;高內聚低…

如何在Linux上部署Ruby on Rails應用程序

在Linux上部署Ruby on Rails應用程序是一個相對復雜的過程&#xff0c;需要按照一系列步驟進行。下面是一個基本的部署過程&#xff0c;涵蓋了從安裝所需軟件到部署應用程序的所有步驟。 安裝必要的軟件 在部署Ruby on Rails應用程序之前&#xff0c;需要確保Linux系統上安裝了…

android 嵌套webview,軟鍵盤遮擋輸入框

實際項目中&#xff0c;android需要加載h5&#xff0c;經常遇到軟鍵盤遮蓋輸入框的情況&#xff0c;h5測試的時候&#xff0c;是沒問題的&#xff0c;但是在APP中是不能把頁面推上去。經測試完美解決了這個問題。 1. oncreate *************************** try {web();layout…

掌握Xcode Storyboard:iOS UI設計的可視化之旅

掌握Xcode Storyboard&#xff1a;iOS UI設計的可視化之旅 在iOS應用程序開發的世界中&#xff0c;用戶界面&#xff08;UI&#xff09;設計是吸引用戶的關鍵。Xcode的Storyboard功能為開發者提供了一個強大的可視化工具&#xff0c;通過拖放的方式快速構建和管理UI。本文將深…

AI網絡爬蟲023:用deepseek批量提取天工AI的智能體數據

文章目錄 一、介紹二、輸入內容三、輸出內容一、介紹 天工AI的智能體首頁: F12查看真實網址和響應數據: 翻頁規律: https://work.tiangong.cn/agents_api/square/sq_list_by_category?category_id=7&offset=0 https://work.tiangong.cn/agents_api/square/sq_list_b…

08 模型演化根本 深度學習推薦算法的五大范式

易經》“九三&#xff1a;君于終日乾乾&#xff1b;夕惕若&#xff0c;厲無咎”。九三是指陽爻在卦中處于第三位&#xff0c;已經到達中位&#xff0c;惕龍指這個階段逐漸理性&#xff0c;德才已經顯現&#xff0c;會引人注目&#xff1b;但要反思自己的不足&#xff0c;努力不…

基于 SSH 的任務調度系統的設計與實現

點擊下載源碼 基于SSH的任務調度系統的設計與實現 摘 要 隨著科學技術的飛速發展和各行各業的分工愈發明細化&#xff0c;對于改革傳統的人工任務調度方式的呼聲越來越大。得益于快速發展的計算機技術&#xff0c;我們看到了改革的方向。本系統是針對企業或者事業單位甚至一個…

Golang | Leetcode Golang題解之第234題回文鏈表

題目&#xff1a; 題解&#xff1a; func reverseList(head *ListNode) *ListNode {var prev, cur *ListNode nil, headfor cur ! nil {nextTmp : cur.Nextcur.Next prevprev curcur nextTmp}return prev }func endOfFirstHalf(head *ListNode) *ListNode {fast : headslo…

camtasia怎么剪掉不用的部分 屏幕錄制的視頻怎么裁剪上下不要的部分 camtasia studio怎么裁剪視頻時長 camtasia怎么剪輯視頻教程

有時我們錄制的屏幕內容&#xff0c;并不一定全部需要。那么&#xff0c;屏幕錄制的視頻怎么裁剪上下不要的部分&#xff1f;可以使用視頻剪輯軟件&#xff0c;或者微課制作工具來進行裁剪。屏幕錄制的視頻怎么旋轉&#xff1f;錄制視頻的旋轉也是一樣的&#xff0c;均在編輯步…

萬字長文之分庫分表里如何優化分頁查詢?【后端面試題 | 中間件 | 數據庫 | MySQL | 分庫分表 | 分頁查詢】

分庫分表的一般做法 一般會使用三種算法&#xff1a; 哈希分庫分表&#xff1a;根據分庫分表鍵算出一個哈希值&#xff0c;根據這個哈希值選擇一個數據庫。最常見的就是數字類型的字段作為分庫分表鍵&#xff0c;然后取余。比如在訂單表里&#xff0c;可以按照買家的ID除以8的…

【Flutter】 webview_flutter避坑

webview_flutter webview_flutter沒有SSL Error接口&#xff0c;也就是說等你的網頁出現SSL 錯誤的時候這個插件無法捕捉處理&#xff0c;除非你改它的源碼。 下面這段是webview_flutter官網的例子&#xff0c;它有onHttpError、onWebResourceError、但沒有任何捕捉 SSL 錯誤…

代謝組數據分析(十五):基于python語言構建PLS-DA算法構建分類模型

介紹 本教程描述了一個具有二元分類結果的研究的典型代謝組學數據分析工作流程。主要步驟包括: 從Excel表格導入代謝物和實驗數據。基于匯總QC的數據清洗。利用主成分分析可視化來檢查數據質量。兩類單變量統計。使用偏最小二乘判別分析(PLS-DA)進行多變量分析,包括: 模型…

go語言 fmt的幾個打印區別以及打印格式

文章目錄 一、打印Print1.1 fmt.Print 和 fmt.Println1.2fmt.Printf1.3 fmt.Sprint, fmt.Sprintf, 和 fmt.Sprintln1.4 fmt.Fprint, fmt.Fprintf, 和 fmt.Fprintln 二、打印格式基本格式動詞整數類型浮點數和復數類型字符串和字節切片布爾類型指針 一、打印Print Go 語言的 fm…

字符串類中的常用方法

1 string對象的創建 靜態創建 String s1  "abc";  String s2  "abc";  動態創建 String s3  new String("abc"); String s4  new String("abc"); 2string對象的不可變性 任何一個String對象在創建之后都不能對它的…

大數據環境下的房地產數據分析與預測研究的設計與實現

1緒論 1.1研究背景及意義 隨著經濟的快速發展和城市化進程的推進&#xff0c;房地產市場成為了國民經濟的重要組成部分。在中國&#xff0c;房地產行業對經濟增長、就業創造和資本投資起到了重要的支撐作用。作為中國西南地區的重要城市&#xff0c;昆明的房地產市場也備受關…

云備份服務端

文件使用工具和json序列化反序列化工具 //文件和json工具類的設計實現 #ifndef __UTIL__ #define __UTIL__ #include<iostream> #include<fstream> #include<string> #include <vector> #include<sys/stat.h> #include"bundle.h" #inc…

FPGA資源容量

Kintex? 7 https://www.amd.com/zh-tw/products/adaptive-socs-and-fpgas/fpga/kintex-7.html#product-table AMD Zynq? 7000 SoC https://www.amd.com/en/products/adaptive-socs-and-fpgas/soc/zynq-7000.html#product-table AMD Zynq? UltraScale? RFSoC 第一代 AMD Z…

【每日一練】python類的構造方法以及常用的魔術方法詳細講解

在Python中&#xff0c;構造方法是一個用來初始化新創建的對象狀態的特殊方法。Python中的構造方法是__init__。此外&#xff0c;Python中的"魔術方法"是Python提供的一系列特殊方法&#xff0c;它們都以雙下劃線開頭和結尾&#xff0c;例如__init__, __str__, __rep…

Redis系列命令更新--Redis列表命令

Redis列表 1、Redis Blpop命令&#xff1a; &#xff08;1&#xff09;說明&#xff1a;Redis Blpop命令移出并獲取列表的第一個元素&#xff1b;如果列表沒有元素會阻塞列表直到等到超時或發現可彈出元素為止 &#xff08;2&#xff09;語法&#xff1a;redis 127.0.0.1:63…

mybaits-plus自定義分頁查詢

1. 引入依賴 在 pom.xml 文件中添加必要的依賴&#xff1a; <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId&…