久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

      如何利用CSS來(lái)美化滑動(dòng)輸入條(input range)?下面本篇文章給大家介紹一下利用純 CSS 自定義滑動(dòng)輸入條樣式的方法,希望對(duì)大家有所幫助!

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

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

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

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

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

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

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

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

      嘗試過(guò)偽元素的想法,像這樣

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

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

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

      二、通過(guò) 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來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

      注意幾點(diǎn):

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

      • 矩形是通過(guò)線(xiàn)性漸變繪制的 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的距離

      接下來(lái)通過(guò)overflow:hidden隱藏外面的部分就可以了

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

      完整代碼可以訪(fǎng)問(wèn):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;

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

      如何利用CSS來(lái)美化滑動(dòng)輸入條?自定義樣式方法淺析

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

      四、簡(jiǎn)單總結(jié)一下

      關(guān)于border-image-outset 這個(gè)屬性,其實(shí)之前已經(jīng)在 MDN 上見(jiàn)識(shí)過(guò)了,但只是簡(jiǎn)單了解,還覺(jué)得很雞肋,現(xiàn)在看來(lái),這些屬性不是沒(méi)什么用,只是沒(méi)有碰到適合應(yīng)用的場(chǎng)景。下面簡(jiǎn)單總結(jié)一下:

      • 滑動(dòng)條有 3 個(gè)偽元素可以自定義容器、軌道、滑塊

      • 偽元素里不能再嵌套偽元素了

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

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

      • 這個(gè)方案不能實(shí)現(xiàn)圓角

      當(dāng)然這些思路都只是“偏方”,像 Firefox 就完全支持自定義樣式了,可惜桌面端還是 Chrome 的天下,只能慢慢期待一下 Chrome 后面的更新了。最后,如果覺(jué)得還不錯(cuò),對(duì)你有幫助的話(huà),歡迎點(diǎn)贊、收藏、轉(zhuǎn)發(fā)❤❤❤

      (學(xué)習(xí)視頻分享:web前端)

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)