checkbox應該是比較常用的html功能了,不過瀏覽器自備的checkbox往往樣式不怎麼好看,而且不同瀏覽器效果也不一樣。出於美化和統一視覺效果的需求,checkbox的自訂就被提出來了。這裡對實作方法做個總結。
純css實作的主要手段是利用label
標籤的模擬功能。 label
的for
屬性可以關聯一個特定的input
元素,即使這個input
本身不可被使用者可見,有個與它對應的label
後,使用者可以直接透過和label
標籤互動來取代原生的input
——而這給我們的樣式模擬留下了空間。簡而言之就是
隱藏原生input,樣式定義的過程留給
label
(那為什麼不直接改變checkbox的樣式?因為checkbox作為瀏覽器預設元件,樣式更改上並沒有label那麼方便,很多屬性對checkbox
都是不起作用的,比如background
,而label
在樣式上基本和div一樣'任人宰割')
而在選擇事件上,由於css的「相鄰選擇子(E+F)」的存在,讓我們可以直接利用html的預設checkbox,免去了js模擬選擇的麻煩。
DEMO的部分CSS3屬性只寫了webkit前綴,所以建議用webkit核心的瀏覽器查看本頁
HTML程式碼:
<div class="wrap"><!-- `input`的id必须有,这个是label进行元素匹配所必需的 --><!-- 可以看到每个input的id和label的“for”属性对应同一字符串 --><input type="checkbox" id="checkbox01" /><label for="checkbox01"></label><input type="checkbox" id="checkbox02" /><label for="checkbox02"></label><input type="checkbox" id="checkbox03" /><label for="checkbox03"></label><input type="checkbox" id="checkbox04" /><label for="checkbox04"></label>
HTML建置完成,接下來是對應的css。
.wrap { width: 500px; background-color: #EEE; border: 2px solid #DEF; }/* 隐藏所有checkbox */input[type='checkbox'] { display: none; }/* 对label进行模拟.背景图片随便拼凑的,不要吐槽品味*//* transition效果是做个背景切换效果,这里单纯演示而已,实际上这个过渡不加更自然*/label { display: inline-block; width: 60px; height: 60px; position: relative; background: url(//www.chitanda.me/images/blank.png); background-position: 0 0px; -webkit-transition: background 0.5s linear; }/* 利用相邻选择符和checkbox`:checked`的状态伪类来模拟默认选中效果(就是点击后那个勾号的效果) *//*如果这段代码注释,点击后将没有任何反馈给用户*//*因为label本身是没有点击后被选中的状态的,checkbox被隐藏后,这个状态只能手动模拟*/input[type='checkbox']:checked+label { background-position: 0 -60px; }
上面程式碼的效果如下所示,看起來好像也可以了。
不過仔細想想,似乎缺了點什麼:選項對應的提示文字
對css不了解的新人可能這時候第一反應就是在label
後面用p
標籤或span
標籤來加入文字。不過這種方式都不太優雅。個人建議用css的::before
和::after
偽元素(::before
和:before
是一個東西。不過為了把「偽元素」和「偽類」區分出來,W3C建議的寫法是偽元素用::
而偽類用:
)
偽元素的具體內容這裡不多說,(其實是我也對它們的掌握就僅限於用用而已,對這個談不上理解,就不誤人子弟了)
/* 伪元素的生效很简单,定义`content`就好,其余的属性和普通div一样 */label::after { content: attr(data-name); /*利用attr可以减少css代码量,data-name写在html部分的label属性里*/ display: inline-block; position: relative; width: 120px; height: 60px; left: 100%; vertical-align: middle; margin: 10px; }
當然既然可以用::after
模擬label的文字,那也就可以用::before
模擬label
的checkbox樣式,這裡就不做解析了。
以上是html中checkbox的自訂效果實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!