1. 程式人生 > 其它 >CSS | CSS利用png圖片替換checkbox樣式

CSS | CSS利用png圖片替換checkbox樣式

技術標籤:# Webcsshtmlcss3CheckBoxcheckbox

一、前言

預設的checkbox長這樣:

複製程式碼

        <p>
            <span><input type="checkbox" /></span>
            <span>空閒</span>
            <span><input type="checkbox" /></span>
            <span>服務中</span>
        </p>

複製程式碼

有點醜,我想把它變成這樣:


二、實現

1、checkbox 難看的框框隱藏掉,改用<label>元素連線到checkbox

複製程式碼

        <p>
            <input type="checkbox" class="e-selfecheckbox" id="place1">
            <label class="selfecheckbox_label" for="place1">空閒</label>

            <input type="checkbox" class="e-selfecheckbox" id="place2">
            <label class="selfecheckbox_label" for="place2">服務中</label>
        </p>
        <style>
            .e-selfecheckbox{
                display: none;
            }
        </style>

複製程式碼

2、隱藏的框框的用自定義圖片來代替

複製程式碼

        <style type="text/css">
            .e-selfecheckbox {
                display: none;
            }
            
            .selfecheckbox_label:before {
                content: "";
                display: inline-block;
                vertical-align: middle;
                width: 13px;
                height: 13px;
                background-image: url(img/scheduling_icon_uncheck2.png);
                background-size: 100%;
            }
        </style>

複製程式碼

3、給checkbox註冊事件,原理就是點選的時候把他替換成另一張圖片

複製程式碼

        <style type="text/css">
            .e-selfecheckbox {
                display: none;
            }
            
            .selfecheckbox_label:before {
                content: "";
                display: inline-block;
                vertical-align: middle;
                width: 13px;
                height: 13px;
                background-image: url(img/scheduling_icon_uncheck2.png);
                background-size: 100%;
            }
            
            /*在e-selfecheckbox元素被選擇的時候,將selfecheckbox_label前面的圖片替換成另一張*/
            .e-selfecheckbox:checked+.selfecheckbox_label:before {
                background-image: url(img/scheduling_icon_checked2.png);
            }
        </style>

複製程式碼

4、實現效果


三、結語

本來思路是想用js來實現這個功能的——點選的時候替換成另一個圖片。結果問了下我們公司的前端,這麼一搞,感覺好高大上啊!

路漫漫其修遠兮,吾將上下而求索。