CSS弧形進度條是一種用CSS技術來呈現進度的方式,以弧形的形式為用戶展示進度的百分比。它通常用于展示下載進度、上傳進度以及表單提交等場景。
/* 弧形進度條樣式 */ .progress { position: relative; width: 150px; height: 150px; border-radius: 50%; /* 將div的邊框半徑設為50%可實現圓形 */ border: 10px solid #f3f3f3; /* 設置邊框的顏色和寬度 */ } .progress::before { content: ""; position: absolute; top: -10px; left: -10px; width: 100%; height: 100%; border-radius: 50%; border: 10px solid rgba(255, 255, 255, 0.3); /* 在弧形進度條外圍添加一個白色半透明邊框 */ } .progress::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; border-radius: 50%; clip: rect(0, 75px, 150px, 0); /* 通過clip屬性來定義只顯示弧形的一半 */ background-color: #008CBA; transform-origin: center center; /* 設置弧形旋轉的中心 */ transform: rotate(45deg); /* 將弧形進行旋轉,45度代表進度為50% */ } /* 這里假設進度為50%作為示例,實際中可通過JS動態改變clip和旋轉的角度來實現動態展示進度 */
關于弧形進度條的實現,我們先使用CSS創建一個高寬相等、圓形的div,通過border-radius屬性將邊框的半徑設為50%來實現圓形效果。然后為這個div設置一個邊框顏色和寬度,這里我們將它設為10px solid #f3f3f3。接著,在這個div上面添加一個偽元素::before,通過position:absolute定位在div的外面,再為它設置一個白色半透明的邊框,這樣可以在視覺上突出弧形的顯示效果。最后,在這個div上面再添加一個偽元素::after,通過clip屬性將該元素裁剪成弧形狀,利用background-color設置前景色,再利用transform屬性旋轉該元素,來實現弧形進度條的效果。
總之,通過CSS技術,我們可以輕松創建一個漂亮的弧形進度條,可根據實際需求進行使用和調整。實現方式靈活多樣,有可以使用SCSS或Sass等CSS預處理器來進行更便捷的編寫。如果您需要用到該效果,在實現過程中,不必拘泥于文中的代碼,應根據自己的需求進行相應的修改和定制。