摘要:我們將使用純打造一些切換開關(guān)并使其擁有類似于的用戶體驗??偨Y(jié)這是一個關(guān)于一些很好的切換開關(guān)示例這種技術(shù)使得一切完全復(fù)合語義,不會增加任何瘋狂的標(biāo)記,并且用純就可以完成。獲取開關(guān)按鈕代碼可以
我們將使用純CSS打造一些切換開關(guān)并使其擁有類似于checkbox的用戶體驗。
很多時候我們都需要用戶通過勾選/取消checkbox來表明他們對一些問題的答案。我們設(shè)置了一個標(biāo)簽,一個checkbox,并在提交表單后獲取checkbox值,以查看用戶是否已經(jīng)選中或取消選中該checkbox。我們都知道默認(rèn)的的checkbox長啥樣,而且還不能通過純CSS的方式來設(shè)置checkbox的樣式。這種元素的樣式由每個瀏覽器引擎多帶帶管理(每個瀏覽器下面checkbox的樣式都可能不一樣)。于是,有一個更統(tǒng)一的界面豈不是會更好?
不要急!一個小小的CSS技巧可以幫助我們解決這個問題。通過將:checkded, :before和:after偽類結(jié)合到我們的checkbox上,我們可以實現(xiàn)一些漂亮并擁有平滑過渡效果的切換型開關(guān)。沒有黑魔法...僅僅是CSS的魅力。下面讓我們開始吧。
HTML需要用到的HTML并不是我們之前沒見過的,也就是一個標(biāo)準(zhǔn)的checkbox結(jié)合一個label。我們用一個div將checkox和label包裹起來,并給這個div添加了一個switch的樣式類。
label的樣式則會使用input + label選擇器來定位,那樣label就不需要自己的樣式類名了?,F(xiàn)在讓我們來看下下面的HTML結(jié)構(gòu):
這里沒什么特別的。對于CSS,我們希望真實的checkbox被隱藏在屏幕和視線之外?;旧纤械臉邮蕉急患釉趌abel上。這樣做很方便,因為點(diǎn)擊label實際上會勾選/取消勾選checkbox。我們將用下面的CSS來實現(xiàn)切換開關(guān):
.cmn-toggle { position: absolute; margin-left: -9999px; visibility: hidden; } .cmn-toggle + label { display: block; position: relative; cursor: pointer; outline: none; user-select: none; }樣式一
此時label充當(dāng)容器的角色,并擁有寬和高。我們還給它設(shè)置了一個背景顏色來模擬我們的切換開關(guān)的邊界。:before元素模擬開關(guān)內(nèi)部的淺灰色區(qū)域(開關(guān)打開時背景顏色會過渡到綠色)。:after元素才是真正的圓形開關(guān),它的層級高于一切,在點(diǎn)擊時的時候它將從左滑動到右。我們將給:after元素添加一個box-shadow使它看起來更加立體。當(dāng)input接受:checked偽類時,我們將平滑的改變:before元素的背景顏色和:after元素的位置。CSS如下:
input.cmn-toggle-round + label { padding: 2px; width: 120px; height: 60px; background-color: #ffffdffffd; border-radius: 60px; } input.cmn-toggle-round + label:before, input.cmn-toggle-round + label:after { display: block; position: absolute; top: 1px; left: 1px; bottom: 1px; content: ""; } input.cmn-toggle-round + label:before { right: 1px; background-color: #f1f1f1; border-radius: 60px; transition: background 0.4s; } input.cmn-toggle-round + label:after { width: 58px; background-color: #fff; border-radius: 100%; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3); transition: margin 0.4s; } input.cmn-toggle-round:checked + label:before { background-color: #8ce196; } input.cmn-toggle-round:checked + label:after { margin-left: 60px; }樣式二
接下來的這個例子和上面的例子非常相似,主要的區(qū)別在于它的外觀表現(xiàn)。它符合現(xiàn)代網(wǎng)站平滑扁平化趨勢,但是就功能而言和例1一樣。下面的CSS僅僅改變了toggle的表現(xiàn)風(fēng)格,其他的都是一樣的。
input.cmn-toggle-round-flat + label { padding: 2px; width: 120px; height: 60px; background-color: #ffffdffffd; border-radius: 60px; transition: background 0.4s; } input.cmn-toggle-round-flat + label:before, input.cmn-toggle-round-flat + label:after { display: block; position: absolute; content: ""; } input.cmn-toggle-round-flat + label:before { top: 2px; left: 2px; bottom: 2px; right: 2px; background-color: #fff; border-radius: 60px; transition: background 0.4s; } input.cmn-toggle-round-flat + label:after { top: 4px; left: 4px; bottom: 4px; width: 52px; background-color: #ffffdffffd; border-radius: 52px; transition: margin 0.4s, background 0.4s; } input.cmn-toggle-round-flat:checked + label { background-color: #8ce196; } input.cmn-toggle-round-flat:checked + label:after { margin-left: 60px; background-color: #8ce196; }樣式三
現(xiàn)在,我們要做一點(diǎn)不一樣的事了。我們將會創(chuàng)建一個翻轉(zhuǎn)風(fēng)格的switcher開關(guān)。默認(rèn)視圖為灰色,并顯示“No”(或任何表示未選中的內(nèi)容),勾選后的視圖則為綠色,并顯示“Yes”。當(dāng)點(diǎn)擊label時,swithcer會沿Y軸翻轉(zhuǎn)180度。我們將使用“data-attributes”來填充未選中/已選中時內(nèi)容。這些“data-attributes”在HTML中由“data-on”和“data-off”指定,他們將分別填充到:after和:before兩個偽元素中。請注意:after偽元素中的backface-visiibility屬性,由于起點(diǎn)是-180度,通過這個屬性可以隱藏背面的內(nèi)容。
input.cmn-toggle-yes-no + label { padding: 2px; width: 120px; height: 60px; } input.cmn-toggle-yes-no + label:before, input.cmn-toggle-yes-no + label:after { display: block; position: absolute; top: 0; left: 0; bottom: 0; right: 0; color: #fff; font-family: "Roboto Slab", serif; font-size: 20px; text-align: center; line-height: 60px; } input.cmn-toggle-yes-no + label:before { background-color: #ffffdffffd; content: attr(data-off); transition: transform 0.5s; backface-visibility: hidden; } input.cmn-toggle-yes-no + label:after { background-color: #8ce196; content: attr(data-on); transition: transform 0.5s; transform: rotateY(180deg); backface-visibility: hidden; } input.cmn-toggle-yes-no:checked + label:before { transform: rotateY(180deg); } input.cmn-toggle-yes-no:checked + label:after { transform: rotateY(0); }瀏覽器兼容性
上面的這些在瀏覽器兼容方面的要求是,IE8及以下的瀏覽器不能識別:checked偽類,因此你需要檢測瀏覽器,如果是老舊的IE,則直接回退到原始的checkbox,css transitions 屬性不支持IE9及以下瀏覽器,但這僅僅會影響切換過程中的過渡部分,除此之外沒有其他毛病能夠正常工作。
總結(jié)這是一個關(guān)于一些很好的CSS切換開關(guān)示例!這種技術(shù)使得一切完全復(fù)合語義,不會增加任何瘋狂的標(biāo)記,并且用純CSS就可以完成。當(dāng)然,你需要注意瀏覽器兼容性情況,但是你可以使用條件樣式來兼容舊版瀏覽器,使用上面提到的例子,并不會產(chǎn)生什么不足之處。
獲取開關(guān)按鈕代碼可以:
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114739.html
摘要:我們將使用純打造一些切換開關(guān)并使其擁有類似于的用戶體驗。總結(jié)這是一個關(guān)于一些很好的切換開關(guān)示例這種技術(shù)使得一切完全復(fù)合語義,不會增加任何瘋狂的標(biāo)記,并且用純就可以完成。獲取開關(guān)按鈕代碼可以 我們將使用純CSS打造一些切換開關(guān)并使其擁有類似于checkbox的用戶體驗。 很多時候我們都需要用戶通過勾選/取消checkbox來表明他們對一些問題的答案。我們設(shè)置了一個標(biāo)簽,一個checkbo...
摘要:我們將使用純打造一些切換開關(guān)并使其擁有類似于的用戶體驗。總結(jié)這是一個關(guān)于一些很好的切換開關(guān)示例這種技術(shù)使得一切完全復(fù)合語義,不會增加任何瘋狂的標(biāo)記,并且用純就可以完成。獲取開關(guān)按鈕代碼可以 我們將使用純CSS打造一些切換開關(guān)并使其擁有類似于checkbox的用戶體驗。 很多時候我們都需要用戶通過勾選/取消checkbox來表明他們對一些問題的答案。我們設(shè)置了一個標(biāo)簽,一個checkbo...
摘要:開關(guān)樣式預(yù)覽圖前言最近在基于框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇某一選項,本來想引用框架自帶的一個按鈕插件,結(jié)果在引用的時候總是出錯,就找了找資源,用純實現(xiàn)這個按鈕開關(guān)的功能。 開關(guān)樣式預(yù)覽圖 showImg(https://segmentfault.com/img/bVyYer); 前言 最近在基于bootstrap框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇...
摘要:開關(guān)樣式預(yù)覽圖前言最近在基于框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇某一選項,本來想引用框架自帶的一個按鈕插件,結(jié)果在引用的時候總是出錯,就找了找資源,用純實現(xiàn)這個按鈕開關(guān)的功能。 開關(guān)樣式預(yù)覽圖 showImg(https://segmentfault.com/img/bVyYer); 前言 最近在基于bootstrap框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇...
摘要:開關(guān)樣式預(yù)覽圖前言最近在基于框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇某一選項,本來想引用框架自帶的一個按鈕插件,結(jié)果在引用的時候總是出錯,就找了找資源,用純實現(xiàn)這個按鈕開關(guān)的功能。 開關(guān)樣式預(yù)覽圖 showImg(https://segmentfault.com/img/bVyYer); 前言 最近在基于bootstrap框架開發(fā)一個網(wǎng)站,在填寫表單一項需要用戶填寫是否選擇...
閱讀 797·2023-04-26 03:04
閱讀 2873·2021-11-15 18:10
閱讀 1199·2021-09-03 10:28
閱讀 1137·2019-08-30 15:53
閱讀 896·2019-08-30 12:45
閱讀 1965·2019-08-30 11:03
閱讀 2870·2019-08-29 14:01
閱讀 2934·2019-08-28 18:24