首頁  >  文章  >  web前端  >  關於CSS和HTML自訂checkbox效果的方法

關於CSS和HTML自訂checkbox效果的方法

不言
不言原創
2018-06-20 10:11:391449瀏覽

checkbox應該是比較常用的html功能了,不過瀏覽器自帶的checkbox往往樣式不怎麼好看,而且不同瀏覽器效果也不一樣.下文給大家分享CSS HTML自訂checkbox效果,一起看看吧

 checkbox應該是比較常用的html功能了,不過瀏覽器自帶的checkbox往往樣式不怎麼好看,而且不同瀏覽器效果也不一樣。出於美化和統一視覺效果的需求,checkbox的自訂就被提出來了。這裡對實作方法做個總結。

實作想法

純css實作的主要手段是利用label標籤的模擬功能。 label的for屬性可以關聯一個特定的input元素,即使這個input本身不可被用戶可見,有個與它對應的label後,用戶可以直接透過和label標籤交互來取代原生的input——而這給我們的樣式模擬留下了空間。簡而言之就是

隱藏原生input,樣式定義的過程留給label (那為什麼不直接改變checkbox的樣式?因為checkbox作為瀏覽器預設元件,樣式變更上並沒有label那麼方便,很多屬性對checkbox都是不起作用的,例如background,而label在樣式上基本和p一樣'任人宰割')
而在選擇事件上,由於css的“相鄰選擇符(E F)”的存在,讓我們可以直接利用html的預設checkbox,免去了js模擬選擇的麻煩。

demo

DEMO的部分CSS3屬性只寫了webkit前綴,所以建議用webkit核心的瀏覽器查看本頁

HTML程式碼:

<p 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=&#39;checkbox&#39;] {
  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=&#39;checkbox&#39;]:checked+label {
  background-position: 0 -60px;
}

上面程式碼的效果如下所示,看起來好像也可以了。

不過仔細想想,似乎缺了點什麼:選項對應的提示文字

對css不了解的新人可能這時候第一反應就是在label後面用p標籤或span標籤來添加文字。不過這種方式都不太優雅。個人建議用css的::before和::after偽元素(::before和:before是一個東西。不過為了把「偽元素」和「偽類」區分出來,W3C建議的寫法是偽元素用::而偽類用:)
偽元素的具體內容這裡不多說,(其實是我也對它們的掌握就僅限於用用而已,對這個談不上理解,就不誤人子弟了)

/* 偽元素的生效很簡單,定義`content`就好,其餘的屬性和普通p一樣 */

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樣式,這裡就不做解析了。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

關於HTML 文字格式化的程式碼

CSS Border屬性之solid的使用介紹

如何使用css transition屬性實作帶有動畫顯隱的微信小程式元件

#

以上是關於CSS和HTML自訂checkbox效果的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn