CSS
jQuery
Webデザイン

CSSの擬似要素のプロパティをjQueryで動的に変えてみた

テスト.gif

たまに使うCSSの::beforeや::after等の擬似要素。

擬似要素のプロパティを動的に変更したい場合、
「jQueryのセレクタに指定して変えればいいじゃーん」
と安易に考えていましたが、この擬似要素、セレクタに直接指定できないようです。。
(擬似要素は非DOMのため。)

それならば、と調べていくと、いくつか方法はあるようでしたが、
個人的にはjQueryでclassを書き換えるやり方が一番しっくりきました。
そこで今回は、そのやり方で、上の動画のように動く
擬似要素::afterを使った入力フォームを実装してみました!

ちなみに擬似要素は左の吹き出しのような△になっている部分です。
image.png

ソースは下記の通り。

■ HTML

<form action="#" method="post" id="regist"></form>
    <table class="member">
        <tbody>
            <tr>
                <th class="default">氏名</div>
                </th>
                <td>
                    <input type="text" name="name" size="30" maxlength="20">
                </td>
            </tr>
            <tr>
                <th class="default">所属</th>
                <td>
                    <input type="text" name="group" size="30" maxlength="20">
                </td>
            </tr>
            <tr>
                <th class="default">メールアドレス</th>
                <td>
                    <input type="text" name="email" size="30" maxlength="20">
                </td>
            </tr>
        </tbody>
    </table>
</form>

■ CSS

table.member {
    width: 500px;
    margin: 0 auto;
    border-collapse: separate;
    border-spacing: 0px 15px;
    font-size: 12px;
}

table.member th,
table.member td {
    padding: 10px;
    text-align: center;
}

/* th デフォルト */

th.default {
    background: #00608d;
    vertical-align: middle;
    text-align: left;
    width: 120px;
    overflow: visible;
    position: relative;
    color: #fff;
    font-weight: normal;
    font-size: 15px;
}

th.default:after {
    left: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(136, 183, 213, 0);
    border-left-color: #00608d;
    border-width: 10px;
    margin-top: -10px;
}


/* th フォーカス時 */

th.change {
    background: #fcc800;
    vertical-align: middle;
    text-align: left;
    width: 120px;
    overflow: visible;
    position: relative;
    color: #fff;
    font-weight: normal;
    font-size: 15px;
}

th.change:after {
    left: 100%;
    top: 50%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
    border-color: rgba(136, 183, 213, 0);
    border-left-color: #fcc800;
    border-width: 10px;
    margin-top: -10px;
}

table.member td {
    background: #f7f6f5;
    width: 360px;
    padding-left: 20px;
}

■ jQuery

$(function () {
        // フォーカスされた時
        $('input[name="name"], input[name="group"], nput[name="email"]').focus(function () {
            // thのクラスを書き換える
            ($(this).parent('td')).prev().removeClass('default');
            ($(this).parent('td')).prev().addClass('change');

        // フォーカスが外れた時
        }).blur(function () {
            // thのクラスを書き換える
            ($(this).parent('td')).prev().removeClass('change');
            ($(this).parent('td')).prev().addClass('default');
        });
    });

■ 備考

今回動的に変えたかったのはth要素とthの擬似要素::afterの色のみです。
そこで、デフォルトで用意したthのクラス「.default」と「.default:after」に対し、
色のみを変えた対になる「.change」と「.change:after」を用意しました。

そして、それぞれの入力欄にフォーカスされた時にjQueryで、
該当のth要素からクラス「.default」を削除し、クラス「.change」を付与。
そして逆に入力欄からフォーカスが外れた時には該当のth要素から
クラス「.change」を削除し、クラス「.default」を付与するようにしています。

もっとスマートなやり方もあるかと思いますので、
参考までにお願いします。

ちなみに、テーブルデザインはLIGさんのブログで
紹介されていたものを参考にさせていただきました。
こんなおしゃれなテーブルデザインをさらっと作れるようになりたい!

HTML5+CSS3でデザインしたtableのCSS&HTMLサンプルソース5点