CSSでログインフォームをデザインする

技術情報
本ページは広告およびアフィリエイトプログラムによる収益を得ています。

今回はCSSでのログインフォームデザインをご紹介いたします。

サンプル

ユーザーアイコンと錠アイコンにクリック、またはタップするとフィールドにカーソルがフォーカスされます。

サンプル

html

ラベルを記述し各フィールドに対応させておくと、アイコンをクリック、またはタップしたときに、入力フィールドにフォーカスが当たるのでおすすめです。

<form id="login" name="login" method="post" action="#" class="login-area">
    <fieldset>
        <dl>
            <dt>ユーザーIDを入力</dt>
            <dd class="user">
                <label for="userid">
                    <span>ユーザーID</span>
                </label>
                <div>
                    <input type="text" id="userid" name="userid" value="" />
                </div>
            </dd>
            <dt>パスワードを入力</dt>
            <dd class="lock">
                <label for="password">
                    <span>パスワード</span>
                </label>
                <div>
                    <input type="password" id="password" name="password" maxlength="64" />
                </div>
            </dd>
        </dl>
    </fieldset>
    <p>
        <button type="submit">送信</button>
    </p>
    <input type="hidden" name="formcmd" value="" />
</form>

css

フォームの基本プロパティとアイコン、ボタンのプロパティに分かれています。

body,dl,dd,p {
    margin: 0;
    padding: 0;
}

body {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* ------------------------------
  基本プロパティ
------------------------------ */
.login-area {
    margin: 10px;
    padding: 15px 10px;
    border: 1px solid #CCC;
}

.login-area fieldset {
    border: none;
}

.login-area dl {
    margin-bottom: 10px;
}

.login-area dl dt {
    margin-bottom: 3px;
}

.login-area dl dd {
    position: relative;
    height: 36px;
    margin-bottom: 20px;
    border: 1px solid #DDD;
}

.login-area dl dd label {
    position: absolute;
    top: 0;
    left: 0;
    width: 36px;
    height: 36px;
    border-right: 1px solid #DDD;
    text-align: center;
}

.login-area dl dd label span {
    visibility: hidden;
}

.login-area dl dd input,
.login-area dl dd div {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: #FEFEFE;
    border: none;
}

.login-area dl dd input {
    width: 100%;
    height: 36px;
    padding: 10px 0;
    outline: none;
}

.login-area dl dd div {
    height: 36px;
    margin: 0;
    padding: 0 10px 0 45px;
}

/* ------------------------------
  アイコン
------------------------------ */
.login-area dl dd label:before,
.login-area dl dd label:after {
    content: "";
    position: absolute;
    top: 50%;
}

/* ユーザーアイコン
----------------------*/
.login-area dl dd.user label:before,
.login-area dl dd.user label:after {
    margin-left: 6px;
}

/* 頭部 */
.login-area dl dd.user label:before {
    left: 9px;
    width: 6px;
    height: 10px;
    margin-top: -7px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-bottom-right-radius: 5px 10px;
    -moz-border-bottom-right-radius: 5px 10px;
    -webkit-border-bottom-right-radius: 5px 10px;
    border-bottom-left-radius: 5px 10px;
    -moz-border-bottom-left-radius: 5px 10px;
    -webkit-border-bottom-left-radius: 5px 10px;
    border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -moz-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -webkit-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    background: #FF9901;
}

/* 体 */
.login-area dl dd.user label:after {
    left: 4px;
    width: 16px;
    height: 5px;
    margin-top: 1px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-radius: 5px 5px 0 0;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    background: #FF9901;
}

/* 錠アイコン
----------------------*/
/* 位置と形 */
.login-area dl dd.lock:before,
.login-area dl dd.lock:after {
    left: 16px;
    z-index: 10;
    width: 3px;
    height: 3px;
    margin-top: 0;
    background: #fff;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

.login-area dl dd.lock label:before,
.login-area dl dd.lock label:after {
    top: 55%;
}

/* 上側 */
.login-area dl dd.lock:before {
    left: 17px;
    width: 1px;
    height: 4px;
    margin-top: 2px;
}

.login-area dl dd.lock label:before {
    left: 13px;
    width: 5px;
    height: 5px;
    margin-top: -11px;
    border: 2px solid #FF9901;
    border-bottom: 0;
    background: transparent;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    border-radius: 5px 5px 0 0;
}

/* 下側 */
.login-area dl dd.lock label:after {
    left: 11px;
    width: 13px;
    height: 10px;
    margin-top: -4px;
    background: #FF9901;
}

/* ------------------------------
  ボタン
------------------------------ */
.login-area p {
    margin-bottom: 12px;
    padding: 0 13px;
}

.login-area button {
    width: 100%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #f6f6f6));
    background: -webkit-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: -moz-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: linear-gradient(to bottom, #ffffff 5%, #f6f6f6 100%);
    background-color: #ffffff;
    border-radius: 6px;
    border: 1px solid #ddd;
    cursor: pointer;
    padding: 10px;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    color: 000;
    text-shadow: 1px 1px 1px #dcdcdc;
}

.login-area button:hover {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #f6f6f6), color-stop(1, #ffffff));
    background: -webkit-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background: linear-gradient(to bottom, #f6f6f6 5%, #ffffff 100%);
    background-color: #f6f6f6;
}

解説1

フィールドなどの線や色、幅などの基本的なプロパティです。

「.login-area dl dd label span」の「visibility: hidden;」でアイコンのテキストを非表示にしています。

/* ------------------------------
  基本プロパティ
------------------------------ */
.login-area {
    margin: 10px;
    padding: 15px 10px;
    border: 1px solid #CCC;
}

.login-area fieldset {
    border: none;
}

.login-area dl {
    margin-bottom: 10px;
}

.login-area dl dt {
    margin-bottom: 3px;
}

.login-area dl dd {
    position: relative;
    height: 36px;
    margin-bottom: 20px;
    border: 1px solid #DDD;
}

.login-area dl dd label {
    position: absolute;
    top: 0;
    left: 0;
    width: 36px;
    height: 36px;
    border-right: 1px solid #DDD;
    text-align: center;
}

.login-area dl dd label span {
    visibility: hidden;
}

.login-area dl dd input,
.login-area dl dd div {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: #FEFEFE;
    border: none;
}

.login-area dl dd input {
    width: 100%;
    height: 36px;
    padding: 10px 0;
    outline: none;
}

.login-area dl dd div {
    height: 36px;
    margin: 0;
    padding: 0 10px 0 45px;
}

解説2

アイコンの上下左右の位置を決めています。

.login-area dl dd label:before,
.login-area dl dd label:after {
    content: "";
    position: absolute;
    top: 50%;
}

.login-area dl dd.user label:before,
.login-area dl dd.user label:after {
    margin-left: 6px;
}

解説3

ユーザーアイコンの頭部と体の大きさを決めています。「radius」で頭部と体の丸みを調整しています。

/* 頭部 */
.login-area dl dd.user label:before {
    left: 9px;
    width: 6px;
    height: 10px;
    margin-top: -7px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-bottom-right-radius: 5px 10px;
    -moz-border-bottom-right-radius: 5px 10px;
    -webkit-border-bottom-right-radius: 5px 10px;
    border-bottom-left-radius: 5px 10px;
    -moz-border-bottom-left-radius: 5px 10px;
    -webkit-border-bottom-left-radius: 5px 10px;
    border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -moz-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -webkit-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    background: #FF9901;
}

/* 体 */
.login-area dl dd.user label:after {
    left: 4px;
    width: 16px;
    height: 5px;
    margin-top: 1px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-radius: 5px 5px 0 0;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    background: #FF9901;
}

解説4

錠アイコンの位置と形を調整しています。

.login-area dl dd.lock:before,
.login-area dl dd.lock:after {
    left: 16px;
    z-index: 10;
    width: 3px;
    height: 3px;
    margin-top: 0;
    background: #fff;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

.login-area dl dd.lock label:before,
.login-area dl dd.lock label:after {
    top: 55%;
}

解説5

錠アイコンの逆Uと■のプロパティ部分です。「radius」で逆Uの丸みを調整しています。

/* 上側 */
.login-area dl dd.lock:before {
    left: 17px;
    width: 1px;
    height: 4px;
    margin-top: 2px;
}

.login-area dl dd.lock label:before {
    left: 13px;
    width: 5px;
    height: 5px;
    margin-top: -11px;
    border: 2px solid #FF9901;
    border-bottom: 0;
    background: transparent;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    border-radius: 5px 5px 0 0;
}

/* 下側 */
.login-area dl dd.lock label:after {
    left: 11px;
    width: 13px;
    height: 10px;
    margin-top: -4px;
    background: #FF9901;
}

解説6

ボタンの背景色は「gradient」プロパティでグラデーションを表現しています。

「.login-area button:hover」でボタンにカーソルがホバーしたときに、グラデーションの上下を反転させています。

.login-area button {
    width: 100%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #f6f6f6));
    background: -webkit-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: -moz-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: linear-gradient(to bottom, #ffffff 5%, #f6f6f6 100%);
    background-color: #ffffff;
    border-radius: 6px;
    border: 1px solid #ddd;
    cursor: pointer;
    padding: 10px;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    color: 000;
    text-shadow: 1px 1px 1px #dcdcdc;
}

.login-area button:hover {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #f6f6f6), color-stop(1, #ffffff));
    background: -webkit-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background: linear-gradient(to bottom, #f6f6f6 5%, #ffffff 100%);
    background-color: #f6f6f6;
}

全ソース

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8" />
<title>
    CSSでログインフォームをデザインする
</title>
<meta name="viewport" content="width=device-width,initial-scale=1" />
<style type="text/css">
body,dl,dd,p {
    margin: 0;
    padding: 0;
}

body {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
}

/* ------------------------------
  基本プロパティ
------------------------------ */
.login-area {
    margin: 10px;
    padding: 15px 10px;
    border: 1px solid #CCC;
}

.login-area fieldset {
    border: none;
}

.login-area dl {
    margin-bottom: 10px;
}

.login-area dl dt {
    margin-bottom: 3px;
}

.login-area dl dd {
    position: relative;
    height: 36px;
    margin-bottom: 20px;
    border: 1px solid #DDD;
}

.login-area dl dd label {
    position: absolute;
    top: 0;
    left: 0;
    width: 36px;
    height: 36px;
    border-right: 1px solid #DDD;
    text-align: center;
}

.login-area dl dd label span {
    visibility: hidden;
}

.login-area dl dd input,
.login-area dl dd div {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: #FEFEFE;
    border: none;
}

.login-area dl dd input {
    width: 100%;
    height: 36px;
    padding: 10px 0;
    outline: none;
}

.login-area dl dd div {
    height: 36px;
    margin: 0;
    padding: 0 10px 0 45px;
}

/* ------------------------------
  アイコン
------------------------------ */
.login-area dl dd label:before,
.login-area dl dd label:after {
    content: "";
    position: absolute;
    top: 50%;
}

/* ユーザーアイコン
----------------------*/
.login-area dl dd.user label:before,
.login-area dl dd.user label:after {
    margin-left: 6px;
}

/* 頭部 */
.login-area dl dd.user label:before {
    left: 9px;
    width: 6px;
    height: 10px;
    margin-top: -7px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-bottom-right-radius: 5px 10px;
    -moz-border-bottom-right-radius: 5px 10px;
    -webkit-border-bottom-right-radius: 5px 10px;
    border-bottom-left-radius: 5px 10px;
    -moz-border-bottom-left-radius: 5px 10px;
    -webkit-border-bottom-left-radius: 5px 10px;
    border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -moz-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    -webkit-border-radius: 5px 5px 5px 5px/5px 5px 10px 10px;
    background: #FF9901;
}

/* 体 */
.login-area dl dd.user label:after {
    left: 4px;
    width: 16px;
    height: 5px;
    margin-top: 1px;
    border-top-right-radius: 5px;
    -moz-border-top-right-radius: 5px;
    -webkit-border-top-right-radius: 5px;
    border-top-left-radius: 5px;
    -moz-border-top-left-radius: 5px;
    -webkit-border-top-left-radius: 5px;
    border-radius: 5px 5px 0 0;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    background: #FF9901;
}

/* 錠アイコン
----------------------*/
/* 位置と形 */
.login-area dl dd.lock:before,
.login-area dl dd.lock:after {
    left: 16px;
    z-index: 10;
    width: 3px;
    height: 3px;
    margin-top: 0;
    background: #fff;
    -moz-border-radius: 3px;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

.login-area dl dd.lock label:before,
.login-area dl dd.lock label:after {
    top: 55%;
}

/* 上側 */
.login-area dl dd.lock:before {
    left: 17px;
    width: 1px;
    height: 4px;
    margin-top: 2px;
}

.login-area dl dd.lock label:before {
    left: 13px;
    width: 5px;
    height: 5px;
    margin-top: -11px;
    border: 2px solid #FF9901;
    border-bottom: 0;
    background: transparent;
    -moz-border-radius: 5px 5px 0 0;
    -webkit-border-radius: 5px 5px 0 0;
    border-radius: 5px 5px 0 0;
}

/* 下側 */
.login-area dl dd.lock label:after {
    left: 11px;
    width: 13px;
    height: 10px;
    margin-top: -4px;
    background: #FF9901;
}

/* ------------------------------
  ボタン
------------------------------ */
.login-area p {
    margin-bottom: 12px;
    padding: 0 13px;
}

.login-area button {
    width: 100%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #f6f6f6));
    background: -webkit-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: -moz-linear-gradient(top, #ffffff 5%, #f6f6f6 100%);
    background: linear-gradient(to bottom, #ffffff 5%, #f6f6f6 100%);
    background-color: #ffffff;
    border-radius: 6px;
    border: 1px solid #ddd;
    cursor: pointer;
    padding: 10px;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    color: 000;
    text-shadow: 1px 1px 1px #dcdcdc;
}

.login-area button:hover {
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0.05, #f6f6f6), color-stop(1, #ffffff));
    background: -webkit-linear-gradient(top, #f6f6f6 5%, #ffffff 100%);
    background: linear-gradient(to bottom, #f6f6f6 5%, #ffffff 100%);
    background-color: #f6f6f6;
}
</style>
</head>
<body>

<form id="login" name="login" method="post" action="#" class="login-area">
    <fieldset>
        <dl>
            <dt>ユーザーIDを入力</dt>
            <dd class="user">
                <label for="userid">
                    <span>ユーザーID</span>
                </label>
                <div>
                    <input type="text" id="userid" name="userid" value="" />
                </div>
            </dd>
            <dt>パスワードを入力</dt>
            <dd class="lock">
                <label for="password">
                    <span>パスワード</span>
                </label>
                <div>
                    <input type="password" id="password" name="password" maxlength="64" />
                </div>
            </dd>
        </dl>
    </fieldset>
    <p>
        <button type="submit">送信</button>
    </p>
    <input type="hidden" name="formcmd" value="" />
</form>

</body>
</html>

まとめ

  • ラベルを各フィールドに対応させておくと、入力フィールドにフォーカスが当たる。
  • フォームの基本プロパティとアイコン、ボタンのプロパティの3つに分かれている。
  • 「visibility: hidden;」でアイコンのテキストを非表示にしている。
  • 「radius」でユーザーアイコンと錠アイコンの丸みを調整している。
  • ボタンの背景色は「gradient」プロパティで表現、「:hover」疑似要素でオンマウス時にグラデーションを反転表示。
スポンサーリンク
技術情報
スポンサーリンク
シェアする
ボヘミアンをフォローする
この記事が気に入ったら
フォローしよう
最新情報をお届けします。
スポンサーリンク

コメント