站長資訊網
        最全最豐富的資訊網站

        如何利用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前端)

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲av无码成人精品区在线播放| 尤物TV国产精品看片在线| 精品久久久久久无码免费| 久久精品国产99久久久| 久久精品国产亚洲AV不卡| 精品一区二区久久| 亚洲国产成人一区二区精品区| 国产成人无码精品一区在线观看| xxx国产精品视频| 亚洲国产成人精品无码区在线观看 | 亚洲高清国产拍精品26U| 久久精品国产99久久香蕉| 2020最新久久久视精品爱| 91国在线啪精品一区| 热re99久久6国产精品免费| 欧美成人精品网站播放 | 亚洲国产精品狼友中文久久久| 国产精品99爱免费视频| 欧美精品华人在线| 国产精品高清一区二区三区不卡| 国产精品ⅴ无码大片在线看| 久久久久无码精品国产| 亚洲高清国产拍精品26U| 亚洲国产精品无码一线岛国| 在线观看国产精品普通话对白精品 | 国产精品免费看久久久香蕉| 91精品国产91久久久久久青草| 华人在线精品免费观看| 国精无码欧精品亚洲一区| 人妻少妇精品视频二区| 日韩欧精品无码视频无删节| 亚洲国产精品无码中文字| 亚洲精品成人网站在线观看| 一区二区国产精品 | 99久久国产综合精品网成人影院 | 94久久国产乱子伦精品免费| 2022免费国产精品福利在线| 国产成人精品无码片区在线观看 | 亚洲国产成人a精品不卡在线| 亚欧乱色国产精品免费视频| 亚洲精品高清无码视频|