干貨-自定義個(gè)性化checkbox

前端工程師和設(shè)計(jì)師一直都是相愛(ài)相殺的兩個(gè)人。

在拿到UI稿時(shí)設(shè)計(jì)師告訴我要做到99%還原。。。滿臉黑線( ̄工 ̄lll)于是乎,就要實(shí)現(xiàn)設(shè)計(jì)師滿意的checkbox。以下為實(shí)現(xiàn)步驟。

Requirement:
要實(shí)現(xiàn)如圖所示的checkbox:

Paste_Image.png

Implementation

  1. 首先,需要讓設(shè)計(jì)師給你一張如下圖所示的png:


    checkbox.png

    這張圖片從左到右依次為,checkbox默認(rèn)狀態(tài)、hover狀態(tài)、選中狀態(tài)、未選中的disabled狀態(tài)、選中的disabled狀態(tài)。

  2. 接下來(lái)就要使用強(qiáng)大的CSS了。
    首先給需要個(gè)性化的checkbox加上以下樣式:
    input[type="checkbox"] {
    -webkit-appearance: none; //去掉checkbox原有的樣式
    }
    然后利用設(shè)計(jì)師給的圖添加checkbox各種狀態(tài)所需要的樣式:
    默認(rèn):
    input[type="checkbox"] {
    -webkit-appearance: none;
    background: url("checkbox.png");
    height: 16px; //每一個(gè)checkbox的高度
    vertical-align: middle;
    width: 16px; //每一個(gè)checkbox的寬度
    }
    選中:
    input[type="checkbox"]:checked {
    background-position: -36px 0; //圖片相對(duì)于當(dāng)前checkbox向左移16 + 2(間距) + 16px,即為選中樣式。
    }
    未選中:
    input[type="checkbox"]:not(:checked) {
    background-position: 0 0;
    }
    未選中hover:
    input[type="checkbox"]:not(:checked):hover {
    background-position: -18px 0;
    }
    選中但disabled:
    input[type="checkbox"][disabled]:checked {
    background-position: -72px 0;
    }
    其他樣式可以自己參考自己設(shè)定。
  3. 兼容性方面:
    目前只兼容 Webkit 系列瀏覽器; Firefox 實(shí)現(xiàn)了替代的 -moz-appearance屬性,不過(guò)控件原有的背景顏色、邊框樣式無(wú)法修改;IE 系列暫時(shí)不支持該屬性。
  4. 為了兼容更多的主流瀏覽器,需要尋求另外的解決方案。
    在所有主流瀏覽器里,點(diǎn)擊關(guān)聯(lián)某個(gè)復(fù)選框的 label 時(shí),產(chǎn)生的效果和點(diǎn)擊元素自身相同,會(huì)切換復(fù)選框控件的選中狀態(tài)。
    既然能用 label 元素來(lái)控制復(fù)選框的狀態(tài),那就不必直接操作實(shí)際的復(fù)選框元素,而把操作和樣式都轉(zhuǎn)移到與之關(guān)聯(lián)的 label 元素上:
    <input id="example" type="checkbox">
    <label for="example"></label>
    確保 label 元素的 for屬性的值和復(fù)選框 input 的 id值一致,同時(shí)將 label 元素放置于 input 之后,這樣 CSS 可以通過(guò)相鄰兄弟選擇器定位到這個(gè) label 元素并為之應(yīng)用樣式:
    input[type="checkbox"] + label:before {
    background: #fff url(i/blue.png);
    content: " ";
    height: 22px;
    left: 0;
    position: absolute;
    width: 22px;
    }
    有了樣式化的 label 元素來(lái)提供交互,原生的 checkbox 控件就顯得有點(diǎn)多余了,雖然可以用 display: none把它隱藏掉,不過(guò)隱藏后的表單元素是不能獲得焦點(diǎn)的,要怎么辦呢?
    當(dāng)然,沒(méi)有什么問(wèn)題用一個(gè)div解決不了的。所以我們做如下修改:

    <div class="checkbox">
    <input id="exampleCheckbox" type="checkbox">
    <label for="exampleCheckbox"></label>
    </div>
    /* css */
    .checkbox {
    min-height: 24px;
    padding-left: 24px;
    position: relative;
    }
    input[type="checkbox"] {
    box-sizing: border-box;
    left: 4px;
    margin: 0;
    padding: 0;
    position: absolute;
    top: 3px;
    }

用一個(gè)div將label和input包含在內(nèi),并設(shè)置div的position為relative,這樣就可以調(diào)整label和checkbox相對(duì)于父div的位置,實(shí)現(xiàn)用 label 元素把checkbox遮住,這樣既能支持鍵盤交互,同時(shí)當(dāng)圖片加載失敗的時(shí)候,又能保證原生的控件可用。
這樣就可以兼容主流瀏覽器啦。

有一個(gè)iCheck庫(kù),可以實(shí)現(xiàn)很好看的checkbox樣式,詳見(jiàn)使用說(shuō)明-中文。但是要實(shí)現(xiàn)各家設(shè)計(jì)師的樣式,還是要自力更生呀。(? ? ?)

參考資料

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,565評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,115評(píng)論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 177,577評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,514評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,234評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,621評(píng)論 1 326
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,641評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 42,822評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,380評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,128評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,319評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,879評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,548評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 34,970評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,229評(píng)論 1 291
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,048評(píng)論 3 397
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,285評(píng)論 2 376

推薦閱讀更多精彩內(nèi)容