目錄
一、我的實作思路
二、透過 border-image 在元素之外繪製圖形
三、還是有一些限制
四、簡單總結一下
首頁 web前端 css教學 如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

Mar 21, 2022 am 11:20 AM
css

如何利用CSS來美化滑動輸入條(input range)?以下這篇文章為大家介紹一下利用純 CSS 自訂滑動輸入條樣式的方法,希望對大家有幫助!

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

關於原生 input range 滑動輸入條如何自訂樣式一直都是我心裡的一道坎,一般情況下,可以很輕易的美化到這個程度。 (推薦學習:css影片教學

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

#為什麼很容易呢?因為這些都是有對應的偽元素可以修改的

::-webkit-slider-container {
  /*可以修改容器的若干样式*/
}
::-webkit-slider-runnable-track {
  /*可以修改轨道的若干样式*/
}
::-webkit-slider-thumb {
  /*可以修改滑块的若干样式*/
}
登入後複製

可是,偏偏沒有已滑過部分的樣式,如果要定義下面這樣的樣式,單純的CSS 可能沒辦法實現了

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

注意:Firefox 有單獨的偽類別可以修改,本文討論的是Chrome 實作方案

一、我的實作思路

既然沒有專門的偽元素可以修改已滑過部分的顏色,而且只有滑塊是可動的,是否可以在滑塊上下手?

假設滑桿左邊有一個長方形,是跟隨滑桿一起的,

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

#當這個矩形夠長時,能夠完全覆蓋左邊的軌道,在可視範圍內,是不是就可以表示左邊的已滑過部分了呢?示意如下(左邊半透明表示滑動條之外)

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

嘗試過偽元素的想法,像這樣

::-webkit-slider-thumb::after{
  /*本想绘制一个足够长的矩形*/
}
登入後複製

可惜,偽元素裡並不能再次產生偽元素。

所以,如何在元素之外畫出一個矩形呢?

二、透過 border-image 在元素之外繪製圖形

有哪些方式可以在元素之外繪製圖形呢?想了一下,有box-shadowoutline,但好像不適合這種情況,我們需要繪製的是一個尺寸可控的矩形,而這兩種方式都不能很好地控制形狀。那還有其他方式嗎?

還真有!前兩天剛看到張鑫旭老師的一篇文章:被低估的border-image屬性,其中有一個特性就是在元素之外構建圖像,並且不佔據任何空間。趕快試試,這裡繪製一個寬度為99vw的矩形(足夠覆蓋滑動條就行了),程式碼如下

::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #f44336;
    border: 1px solid transparent;
    margin-top: -8px;
    border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0 0 0 99vw; /*绘制元素外矩形*/
}
登入後複製

效果如下

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

注意幾點:

  • border-image 要生效,必須指定border,這裡設定的是border: 1px solid transparent;

  • 矩形是透過線性漸層繪製的linear-gradient(#f44336,#f44336)

  • #border -image 中8 20 8 0表示border-image-width,距離上、右、下、左的距離,由於滑桿本身大小是20 * 20,所以這個可以確定高度是4 (20 - 8- 8),位置是滑桿本身的最左邊(距離右邊是20)

  • border-image 中0 0 0 99vw表示border-image-outset擴充大小,這裡指的是向左擴展99vw的距離

接下來通過overflow:hidden隱藏外面的部分就可以了

::-webkit-slider-container {
    /*其他样式*/
    overflow: hidden;
}
登入後複製

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

#完整程式碼可以存取:input range

https:// codepen.io/xboxyan/pen/YzERZyE

下面附上完整程式碼(最近codepen似乎不太穩定)

[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
    outline: 0;
    background-color: transparent;
    width: 500px;
}
[type="range"]::-webkit-slider-runnable-track {
    height: 4px;
    background: #eee;
}
[type="range" i]::-webkit-slider-container {
    height: 20px;
    overflow: hidden;
}
[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background-color: #f44336;
    border: 1px solid transparent;
    margin-top: -8px;
    border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0px 0px 0 2000px;
}
登入後複製

三、還是有一些限制

上面的實作成本其實是很低的,相比常規的實作基礎上,僅僅增加了1行用於繪製元素之外的矩形。

border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0px 0px 0 2000px;
登入後複製

但是,由於是透過超出隱藏的方式裁剪掉多出的部分,使得滑動條邊緣是「一刀切」的,所以,如果要求滑動條帶有圓角,這種實現方式就不行了

如何利用CSS來美化滑動輸入條?自訂樣式方法淺析

如果還有好的想法歡迎留言討論

四、簡單總結一下

關於border-image-outset 這個屬性,其實之前已經在MDN 上見識過了,但只是簡單了解,還覺得很雞肋,現在看來,這些屬性不是沒什麼用,只是沒有碰到適合應用的場景。以下簡單總結一下:

  • 滑動條有3 個偽元素可以自訂容器、軌道、滑桿

  • 偽元素裡不能再巢狀偽元素了

  • 元素之外繪製有box-shadow、outline、border-image 3種方法

  • ##border-image 可以使用任意格式圖片,包括CSS 漸變

  • 這個方案不能實現圓角

當然這些思路都只是“偏方”,像Firefox 就完全支援自訂樣式了,可惜桌面端還是Chrome 的天下,只能慢慢期待一下Chrome 後面的更新了。最後,如果覺得還不錯,對你有幫助的話,歡迎按讚、收藏、轉發❤❤❤

(學習影片分享:

web前端

以上是如何利用CSS來美化滑動輸入條?自訂樣式方法淺析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

HTML,CSS和JavaScript的角色:核心職責 HTML,CSS和JavaScript的角色:核心職責 Apr 08, 2025 pm 07:05 PM

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

vue中怎麼用bootstrap vue中怎麼用bootstrap Apr 07, 2025 pm 11:33 PM

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

bootstrap怎麼寫分割線 bootstrap怎麼寫分割線 Apr 07, 2025 pm 03:12 PM

創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

bootstrap怎麼調整大小 bootstrap怎麼調整大小 Apr 07, 2025 pm 03:18 PM

要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

了解HTML,CSS和JavaScript:初學者指南 了解HTML,CSS和JavaScript:初學者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

bootstrap怎麼設置框架 bootstrap怎麼設置框架 Apr 07, 2025 pm 03:27 PM

要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

bootstrap怎麼插入圖片 bootstrap怎麼插入圖片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

bootstrap按鈕怎麼用 bootstrap按鈕怎麼用 Apr 07, 2025 pm 03:09 PM

如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本

See all articles