ウェブフォームへのスタイル設定
これまでのいくつかの記事では、ウェブフォームを作成し、構成するために必要なすべての HTML について見てきました。この記事では、CSS を使用してフォームコントロールのスタイルを設定する方法について移動します。これは過去には難しいことでした。フォームコントロールは CSS でカスタマイズしやすいかどうかで大きく異なりますが、古いブラウザーが引退し、現代のブラウザーがより多くの機能を使用するようになるにつれて、簡単になってきています。
なぜフォームウィジェットへのスタイル設定は難しいのか
1995 年頃に HTML 2 仕様書へフォームコントロールが追加されました。 CSS は 1996 年までリリースされず、その後も数年は部hラウザーの対応が充分ではありませんでした。ブラウザーは、フォームコントロールの管理とレンダリングを、オペレーティングシステムに頼っていました。
CSS が HTML のスタイル設定できるようになってからも、ユーザーは各プラットフォームの視覚的な外見に慣れていましたので、ブラウザーベンダーはフォームコントロールをスタイル付け可能にすることに乗り気ではありませんでした。しかしこれは変わりました。ウェブサイトのオーナーはこれまでよりも、サイト全体に適するスタイルを欲しており、ウェブプラットフォームはこれを実現可能にしました。
一部のフォームウィジェットは、コントロールをスタイル設定できるように作成し直すのは難しいのですが、ユーザビリティを破綻させないよう気をつける必要はあるものの、 CSS を使って多くのフォーム機能をスタイル設定できます。
CSS を使用する場合、すべてのウィジェットが同じように作成されるわけではない
いまだに、フォームで CSS を使用する際に困ることが存在します。この問題は、3 つのカテゴリーに分けられます。
良好
いくつかの要素はプラットフォーム間の問題があるとしても、ほとんど問題なくスタイルを設定できます。これらは以下の構造的な要素が含まれます。
<form>
<fieldset>
と<legend>
- 単一行のテキストの
<input>
(例えば text, url, email 型)<input type="search">
以外 - 複数行の
<textarea>
- ボタン(
<input>
と<button>
の両方) <label>
<output>
不良
一部の要素はほとんどスタイル設定ができず、時に CSS の高度な知識やトリックが必要になるかもしれません。
- チェックボックスとラジオボタン
<input type="search">
これら特殊なケースをどのように扱うかについては、フォームへの高度なスタイル設定の記事で見ていきます。
劣悪
一部の要素は、CSS でスタイルを設定できません。たとえば次のものです。
<input type="color">
<input type="datetime-local">
のような日時関連コントロール<input type="range">
<input type="file">
- ドロップダウンウィジェットの作成に含まれる要素、
<select>
,<option>
,<optgroup>
,<datalist>
を含む。 <progress>
と<meter>
これらの要素をスタイル設定するのに関して何ができるかについては、フォームへの高度なスタイル設定の記事で見ていきます。
これらすべてのウィジェットの主な問題は、ウィジェットの構造がとても複雑であるという事実と、(コントロールの width や margin の変更といった)基本的なスタイル設定を超えると、現在の CSS では(例えばカレンダー日付ピッカーや、選択肢のリストを表示する <select> のボタンのような)ウィジェットの細かい部分すべてにスタイルを設定できるほどの表現力がないことによります。
これらのウィジェットを完全にカスタマイズしたい場合は、 HTML, CSS, JavaScript を使って独自のものを作成する必要があります。それはこのコアフォームの記事の範囲を超えますが、高度な記事のカスタムウィジェットの作成方法の記事で説明します。
メモ: フォームコントロールの内部コンポーネントにスタイル設定するプロプライエタリな CSS 擬似要素、例えば ::-moz-range-track
がありますが、これはブラウザー同士で整合していないので、これに頼るべきではありません。これについては後程でも触れます。
良好
CSS でスタイルを設定するのが簡単なフォームコントロールは、他の HTML 要素とほとんど同じように動作するため、困難はあまりないはずです。最初のフォームで、いくつかの簡単なフォームのスタイルを既に見ましたし、 CSS の構成要素モジュールにもいくつかの役立つフォームのスタイル設定の基本が含まれています。
CSS でのスタイル設定が容易な要素は、振る舞いが他の HTML 要素とほとんど同じであるため、問題に直面することはないでしょう。ただし、ブラウザー間でユーザーエージェントのスタイルシートが若干矛盾するかもしれませんので、より簡単にスタイルを設定できるようにするためのトリックがあります。
この記事の最後で基本的なフォームコントロールのスタイル設定と配置について理解できる実例を詳しく見ていきます。しかしその前に、知っておくと良いフォームスタイル設定の特定の面をいくつか述べておきます。
フォントとテキスト
CSS のフォントやテキストの機能は、任意のウィジェットで容易に使用できます(また、フォームウィジェットで @font-face
も使用できます)。ただし、ブラウザーの動作にしばしば矛盾があります。デフォルトで、一部のブラウザーは親から font-family
や font-size
を継承しません。代わりに多くのブラウザーでは、システムのデフォルトの体裁を使用します。フォームの体裁を他のコンテンツと一致させるには、以下のルールをスタイルシートに追加するとよいでしょう。
css
button,
input,
select,
textarea {
font-family: inherit;
font-size: 100%;
}
inherit
のプロパティ値で、プロパティ値は計算された親要素のプロパティ値に一致するようになります。つまり親の値を継承します。
以下のスクリーンショットで違いを示します。左側は Mac OS X の Chrome における <input type="text">
, <input type="date">
, <select>
, <textarea>
, <input type="submit">
, <button>
要素の既定のレンダリングで、プラットフォームのキテイノフォントスタイルを使用しています。右側は同じ要素ですが、フォントを調和させるスタイルルールを適用したものです。
既定はいろいろと変わります。継承により、フォントは親のフォントファミリーに変更されます — ここでは親コンテナーの既定の serif フォントです。ほぼすべてそうですが、例外として Chrome では<input type="submit">
は親段落を継承しません。むしろ、font-family: system-ui
を使います。これは同等な入力タイプの中で <button>
要素を使う理由です。
フォームはシステムの既定のスタイルを使用するか、コンテンツに合うよう設計されたカスタムスタイルを使用するかについては多くの議論があります。これを決めるのは、設計者としてサイトやウェブアプリケーションを作成するあなた次第です。
ボックスモデル
すべてのテキストフィールドは、CSS のボックスモデルに関する全プロパティ (width
、height
、padding
、margin
、および border
) を完全にサポートしています。ただし前述のとおり、ブラウザーがウィジェットを表示する際はシステムのデフォルトスタイルに依存します。コンテンツに対してそれらをどのように混ぜ合わせるかを決めるのは、あなた次第です。ウィジェットでネイティブのルックアンドフィールを維持したいのでしたら、ウィジェットのサイズを調和させたい場合に若干の問題に直面するでしょう。
**これは各ウィジェットが境界、パディング、マージンについて独自のルールを持っているためです。**このためさまざまなウィジェットを同じサイズにしたい場合に、 box-sizing
プロパティを使用しなければなりません。
css
input,
textarea,
select,
button {
width: 150px;
padding: 0;
margin: 0;
box-sizing: border-box;
}
下のスクリーンショットで、左の列は <input type="radio">, <input type="checkbox">, <input type="range">, <input type="text">, <input type="date"> input, <select>
, <textarea>
,<input type="submit">, <button>
の既定の描画、右の列は同じ要素に上のルールを使用して作成したものです。各種のウィジェットのプラットフォームのデフォルトルールと比較して、すべての要素が同じ領域を占めるようにすることが可能な点に注目してください。
スクリーンショットではわからないかもしれませんが、ラジオやチェックボックスの操作はそのままで、 width
プロパティで提供される 150px の水平空間に中央配置されています。他のブラウザーでは、ウィジェットが中央に配置されないことがありますが、割り当てられた空間は守られます。
legend の配置
<legend>
要素はスタイル設定では問題ありませんが、その配置を操作するのは少し厄介かもしれません。既定では、それは常に親である <fieldset>
の上境界の上、左上隅の近くに配置されます。他の場所、例えばfieldsetの内部や左下隅の近くに配置するには、位置指定に頼る必要があります。
下記の例を見てください。
この方法で legend を配置するには、次の CSS を使います(単純化するため、他の宣言は削除しています)。
css
fieldset {
position: relative;
}
legend {
position: absolute;
bottom: 0;
right: 0;
}
<fieldset>
も位置指定する必要があり、 <legend>
がそこから相対的に位置指定されます(そうでなければ <legend>
は <body>
に合わせて位置決めされます)。
<legend>
要素はアクセシビリティにとってとても重要です。フィールドセット内の各フォーム要素のラベルの一部として支援技術によって読み上げられます。しかし、上記のようなテクニックを使用しても問題ありません。 legend の内容はこれまでと同じように読み上げられます。見た目の位置が変更されただけです。
メモ: transform
プロパティを使用して <legend>
の位置指定に役立てることもできます。しかし、例えば transform: translateY();
を使って配置すると、移動はするものの <fieldset>
の枠に醜い隙間ができて、簡単には除去できません。
具体的なスタイル設定の例
HTML フォームにスタイルを設定する方法の具体例を見ていきましょう。以下のような「はがき」風の連絡フォームを作成します。完成バージョンはこちら。
この例をやってみるのであれば、 postcard-start.html ファイルをコピーして、次のやり方に従ってください。
HTML
HTML は、ガイドの最初の記事で使用したものより少しだけ複雑です。いくつか ID やタイトルを追加しています。
html
<form>
<h1>to: Mozilla</h1>
<div id="from">
<label for="name">from:</label>
<input type="text" id="name" name="user_name" />
</div>
<div id="reply">
<label for="mail">reply:</label>
<input type="email" id="mail" name="user_email" />
</div>
<div id="message">
<label for="msg">Your message:</label>
<textarea id="msg" name="user_message"></textarea>
</div>
<div class="button">
<button type="submit">Send your message</button>
</div>
</form>
上記のコードを HTML の body に追加します。
資産を揃える
ここからがおもしろいところです! コードを書き始める前に、ここでは 3 つの追加要素が必要です。
- はがきの背景 — この画像をダウンロードして作業している HTML ファイルと同じディレクトリーに保存します。
- タイプライター風フォント: fontsquirrel.com の "Secret Typewriter" — TTF ファイルを上記と同じディレクトリーにダウンロードします。
- 手書き風フォント: fontsquirrel.com の "Journal" — TTF ファイルを上記と同じディレクトリーにダウンロードします。
始める前にフォントの処理が必要です。
- fontsquirrel の Webfont Generator に移動します。
- フォームを使って、両方のフォントファイルをアップロードして webfont キットを生成します。キットをコンピューターにダウンロードします。
- zip ファイルを展開します。
- 展開した中身には 2 つの
.woff
ファイルと 2 つの.woff2
ファイルがあります。このファイルを、前と同じ fonts というディレクトリーにコピーします。各フォントの 2 つのファイルはブラウザー互換性を最大化するのに使います; より詳しい情報は Web fonts の記事を見てください。
CSS
ここから例の CSS を見ていきましょう。<style>
要素の中にすべてのコードブロックを一つ一つ追加します。
全体レイアウト
まず、 @font-face
ルールと、すべての <body>
と <form>
要素に設定するスタイルを定義して準備します。 fontsquirrel 出力が上記で述べたものと異なる場合、 stylesheet.css
ファイル内にダウンロード済みの webfont キットの中から正しい @font-face
ブロックを見つけることができます(下記の @font-face
ブロックをそれで置換し、パスをフォントファイルのものに更新する必要があります)。
css
@font-face {
font-family: "handwriting";
src:
url("fonts/journal-webfont.woff2") format("woff2"),
url("fonts/journal-webfont.woff") format("woff");
font-weight: normal;
font-style: normal;
}
@font-face {
font-family: "typewriter";
src:
url("fonts/veteran_typewriter-webfont.woff2") format("woff2"),
url("fonts/veteran_typewriter-webfont.woff") format("woff");
font-weight: normal;
font-style: normal;
}
body {
font: 1.3rem sans-serif;
padding: 0.5em;
margin: 0;
background: #222;
}
form {
position: relative;
width: 740px;
height: 498px;
margin: 0 auto;
padding: 1em;
box-sizing: border-box;
background: #fff url(background.jpg);
/* we create our grid */
display: grid;
grid-gap: 20px;
grid-template-columns: repeat(2, 1fr);
grid-template-rows: 10em 1em 1em 1em;
}
注意として、フォームのレイアウトに CSS グリッドとフレックスボックス を使っています。これで、タイトルやフォーム要素といった各要素を配置できます。
css
h1 {
font:
1em "typewriter",
monospace;
align-self: end;
}
#message {
grid-row: 1 / 5;
}
#from,
#reply {
display: flex;
}
ラベルとコントロール
そして、フォーム要素自体に対するスタイル設定を始めます。まずは、 <label>
に適切なフォントを割り当てましょう。
css
label {
font:
0.8em "typewriter",
sans-serif;
}
テキストフィールドには、共通のルールがいくつか必要です。 border
や background
の削除と padding
や margin
の再定義を行います。
css
input,
textarea {
font:
1.4em/1.5em "handwriting",
cursive,
sans-serif;
border: none;
padding: 0 10px;
margin: 0;
width: 80%;
background: none;
}
これらのフィールドのいずれかがフォーカスされると、ライトグレーの透明な背景でハイライトされます(ユーザビリティとキーボードアクセシビリティのために、フォーカススタイルを保有することは常に重要です)。
css
input:focus,
textarea:focus {
background: rgba(0, 0, 0, 0.1);
border-radius: 5px;
}
これでテキストフィールドのスタイル設定が完了しましたが、次は単一行および複数行のテキストフィールドの表示が同じになるよう調整しなければなりません。一般に、これらの既定の表示が同じでないためです。
テキストエリアの微調整
<textarea>
要素は既定でブロック要素としてレンダリングされるようにします。ここで重要なことは、 resize
プロパティと overflow
プロパティの 2 つです。ここでは固定サイズでデザインしているため、ユーザーが複数行のテキストフィールドをリサイズできないように resize
プロパティを使用します。 overflow
プロパティは、ブラウザー間でのフィールドの一貫性を向上させるために使用します。これの既定値が auto
であるブラウザーと scroll
であるブラウザーが存在します。この例では、すべてのブラウザーが auto
になるようにするのがよいでしょう。
css
textarea {
display: block;
padding: 10px;
margin: 10px 0 0 -10px;
width: 100%;
height: 90%;
border-right: 1px solid;
/* resize : none; */
overflow: auto;
}
送信ボタンにスタイル設定する
<button>
要素は、 CSS によってより便利になります。擬似要素を含めて、行いたいことが何でもできます。
css
button {
padding: 5px;
font: bold 0.6em sans-serif;
border: 2px solid #333;
border-radius: 5px;
background: none;
cursor: pointer;
transform: rotate(-1.5deg);
}
button:after {
content: " >>>";
}
button:hover,
button:focus {
outline: none;
background: #000;
color: #fff;
}
最終結果
スキルを試しましょう!
この記事の終わりまで到達しました。しかし、肝要な点を思い起こせるでしょうか?次に進む前に、テストによって知識の定着を試すことができます——スキルテスト:スタイル設定の基本 (en-US)をご覧ください。
まとめ
ご覧いただいたとおり、テキストフィールドとボタンだけでフォームを作成する限りでは、CSS を使用したスタイル設定は容易です。次の記事では、「不良」や「劣悪」に分類されているウィジェットの扱い方を見ていきます。