自動化無しに生活無し

WEB開発関係を中心に備忘録をまとめています

CSS3でiOS風のトグルスイッチを作る方法【transition+checkbox】

thumbnail

CSS3で実装されたtransitionと兄弟要素のセレクタを組み合わせることでiOS風のトグルスイッチは簡単に作れる。

何も装飾を施していないinputタグのチェックボックスは小さくて見づらいが、この装飾を施すことで、視覚的にも押すことができるスイッチであると認識できるし、押せる範囲が広がる。

iOS風のトグルスイッチの作り方

まずはHTML5から。

<div class="ui_demo_area">
    <input id="ios_chk_01" class="ui20-input_chk" type="checkbox"><label class="ui20-ios_conf" for="ios_chk_01"></label>
</div>

続いて、CSS3。

/* ios button */
.ui20-input_chk {
    display:none;
}
.ui20-ios_conf {
    display:inline-block;
    position:relative;
    padding:1rem 2rem;
    margin:0.25rem;
    border-radius:1rem;
    background:darkgray;
    transition:0.2s;
    cursor:pointer;
}
.ui20-ios_conf::before {
    content:"";
    position:absolute;
    top:-1px;
    left:0;
    width:50%;
    height:100%;
    border:1px solid gray;
    border-radius:1rem;
    background:white;
    transition:0.2s;
}
input[type="checkbox"].ui20-input_chk:checked + label.ui20-ios_conf{ background:lime; }
input[type="checkbox"].ui20-input_chk:checked + label.ui20-ios_conf::before{ left:50%; }

これを実行するとこんな感じになる。

iOS風のトグルスイッチ

ONにしたときはライム色、OFFにしたときは灰色になる。

解説

まず、HTMLのチェックボタンは装飾に邪魔なので、display:none;で消す。display:none`で消したとしても、チェックボックスとしては機能するので問題はない。

続いて、チェックボックスに関連付けたラベル要素を装飾する。本体はposition:relativeとして、疑似要素をposition:absoluteとする。こうすることで、本体はスイッチ全体を、疑似要素はつまみの部分を表現することができる。

疑似要素と本体

そして、このコードの肝はCSS3最終行の+を使用したセレクタ。

これは、隣接している別のHTML要素を指定するためのセレクタ。つまり、input[type="checkbox"].ui20-input_chk:checked + label.ui20-ios_confの意味は、.ui20-input_chkがチェックされている状態の時、隣接するlabelタグで.ui20-ios_confを指定すると言う意味。

すなわち、そのままでは背景灰色でつまみは左、チェックすればつまみを右にして背景をライム色にするということ。

さらに、transitionを使用することで遅延描画させ、スライドにアニメーションをつける。これで本物のiOSのトグルスイッチに近づけたというわけ。

結論

この装飾を応用すれば、回転式のつまみやドアノブなども表現できる。

ウェブアプリ制作との相性は抜群。通常のスマホアプリにありがちなスイッチを真似て表現することで、ユーザビリティの大幅な向上が期待できる。

【関連記事】CSS3を使用した簡単アニメーションの実装【transitionとtransform】

スポンサーリンク