溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么用CSS來美化滑動(dòng)輸入條

發(fā)布時(shí)間:2022-03-21 11:35:00 來源:億速云 閱讀:172 作者:小新 欄目:web開發(fā)

這篇文章主要為大家展示了“怎么用CSS來美化滑動(dòng)輸入條”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“怎么用CSS來美化滑動(dòng)輸入條”這篇文章吧。

關(guān)于原生 input range 滑動(dòng)輸入條如何自定義樣式一直都是我心里的一道坎,一般情況下,可以很輕易的美化到這個(gè)程度。

怎么用CSS來美化滑動(dòng)輸入條

為什么很容易呢?因?yàn)檫@些都是有對(duì)應(yīng)的偽元素可以修改的

::-webkit-slider-container {
  /*可以修改容器的若干樣式*/
}
::-webkit-slider-runnable-track {
  /*可以修改軌道的若干樣式*/
}
::-webkit-slider-thumb {
  /*可以修改滑塊的若干樣式*/
}

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

怎么用CSS來美化滑動(dòng)輸入條

注意:Firefox 有單獨(dú)的偽類可以修改,本文討論的是 Chrome 實(shí)現(xiàn)方案

一、我的實(shí)現(xiàn)思路

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

假設(shè)滑塊左邊有一個(gè)矩形,是跟隨滑塊一起的,

怎么用CSS來美化滑動(dòng)輸入條

當(dāng)這個(gè)矩形足夠長(zhǎng)時(shí),能夠完全覆蓋左邊的軌道,在可視范圍內(nèi),是不是就可以表示左邊的已滑過部分了呢?示意如下(左邊半透明表示滑動(dòng)條之外)

怎么用CSS來美化滑動(dòng)輸入條

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

::-webkit-slider-thumb::after{
  /*本想繪制一個(gè)足夠長(zhǎng)的矩形*/
}

可惜,偽元素里并不能再次生成偽元素。

所以,如何在元素之外繪制一個(gè)矩形呢?

二、通過 border-image 在元素之外繪制圖形

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

還真有!前兩天剛看到張?chǎng)涡窭蠋煹囊黄恼拢罕坏凸赖腷order-image屬性,其中有一個(gè)特性就是在元素之外構(gòu)建圖像,并且不占據(jù)任何空間。趕緊試試,這里繪制一個(gè)寬度為99vw的矩形(足夠覆蓋滑動(dòng)條就行了),代碼如下

::-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來美化滑動(dòng)輸入條

注意幾點(diǎn):

  • border-image 要想生效,必須指定border,這里設(shè)置的是border: 1px solid transparent;

  • 矩形是通過線性漸變繪制的 linear-gradient(#f44336,#f44336)

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

  • border-image 中 0 0 0 99vw表示 border-image-outset擴(kuò)展大小,這里指的是向左擴(kuò)展99vw的距離

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

::-webkit-slider-container {
    /*其他樣式*/
    overflow: hidden;
}

怎么用CSS來美化滑動(dòng)輸入條

完整代碼可以訪問:input range

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

下面附上完整代碼(最近c(diǎn)odepen貌似不太穩(wěn)定)

[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;
}

三、還是有一些局限

上面的實(shí)現(xiàn)成本其實(shí)是很低的,相比常規(guī)的實(shí)現(xiàn)基礎(chǔ)上,僅僅增加了1行用于繪制元素之外的矩形。

border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0px 0px 0 2000px;

但是,由于是通過超出隱藏的方式裁剪掉多出的部分,使得滑動(dòng)條邊緣是“一刀切”的,所以,如果要求滑動(dòng)條帶有圓角,這種實(shí)現(xiàn)方式就不行了

怎么用CSS來美化滑動(dòng)輸入條

以上是“怎么用CSS來美化滑動(dòng)輸入條”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI