icon
icon

selectとoptionをCSSでカスタマイズする方法を現役エンジニアが解説【初心者向け】

初心者向けにselect optionをCSSでカスタマイズする方法について解説しています。これは選択式のメニューを作成するものです。プルダウン式やリスト型の選択式メニューを設置するときの書き方、実際の見え方と動作を確認しましょう。

テックアカデミーマガジンは受講者数No.1のプログラミングスクール「テックアカデミー」が運営。初心者向けにプロが解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。 ※ アンケートモニター提供元:GMOリサーチ株式会社 調査期間:2021年8月12日~8月16日  調査対象:2020年8月以降にプログラミングスクールを受講した18~80歳の男女1,000名  調査手法:インターネット調査

select optionをCSSでカスタマイズする方法についてテックアカデミーのメンター(現役Webデザイナー)が初心者向けに解説します。

目次

1時間でできる無料体験!

 

CSSについてそもそもよく分からないという方は、CSSの書き方について解説した記事をまずご覧ください。

 

田島悠介

今回は、CSSに関する内容だね!

大石ゆかり

どういう内容でしょうか?

田島悠介

select optionをCSSでカスタマイズする方法について詳しく説明していくね!

大石ゆかり

お願いします!

 

select optionとは?

select optionとは、<select>タグの<option>タグのことで、画面上の見た目では選択式メニューの選択肢にあたります。
主に入力フォームで複数の選択肢から1つを選ばせるときに使用します。

プルダウン式の選択式メニュー、またはリスト型の選択式メニューを設置することが可能です。

 

[PR] Webデザインで副業する学習方法を動画で公開中

select optionの書き方

<select>タグを使用したプルダウン型の選択式メニューは、次のように書きます。

HTML:

<select name="住所">
  <option value="tokyo">東京都</option>
  <option value="kanagawa">神奈川県</option>
  <option value="chiba">千葉県</option>
  <option value="saitama">埼玉県</option>
  <option value="ibaraki">茨城県</option>
</select>

 

リスト型の場合は、<select>タグのsize属性に、リスト内に表示する行数を値に設定します。

HTML:

<select size="5">

 

入力フォームなどでは、<select>タグのname属性の値と、選択された<option>タグのvalue属性の値がセットで送信される仕組みです。
例えば、上記のような場合に、「東京都」が選択されると、下記の情報を送信することができます。

住所=tokyo 

 

 

select optionの文字を配置する方法

プルダウン型の選択式メニューでは<select>タグの一番上の<option>タグのテキストが初期選択値として表示されます。

または、<option>タグにselected属性が設定されている場合には、selected属性が設定された<option>タグのテキストが初期選択値として表示されます。

<option>のhidden属性を使用して、以下のように選択値以外の値を表示することもできます。

プルダウン型の選択式メニューでは、hidden属性を設定した<option>タグのテキストが表示されますが、選択肢として選択できません。
ユーザーへの操作の説明として利用し、選択肢をコンパクトにまとめることができます。

一方、リスト型の選択式メニューでは、hidden属性のある<option>タグのテキストは表示されず、選択肢としても選択できません。

 

コラム

コスパとタイパ、両方結果的に良くなる良くなる学び方とは?

「スクールは高いし時間も縛られて効率が悪い」と考える方は多いと思います。
もちろん、時間も費用もかかることは間違いありません。
ただ 結果的に無駄な学びにお金も時間もかける方がリスクが高いという考えもあります。

コスパ・タイパ最適化の参考として、 テックアカデミー卒業生がスクールを選んだ理由 をご紹介します。

  • ・困ったときに、質問や相談できる相手がいるため挫折しなかった
  • ・プロとして必要なスキルのみを深く学べたので無駄がなかった
  • ・副業案件の提供と納品までのサポートがあったので目的を達成できた

安価・短期間で広く浅く学んでも意味がありません。 本当に自分の目的が達成できるか、それが重要です。
自分にどのスキルや学び方が合っているか、どんな学習方法かなど、お気軽に 無料相談 に参加してみませんか?

カウンセラー・現役のプロへ、何でも気軽に無料相談可能。 30分か60分お好きな時間が選べて、かつ3回まで すべて無料で ご利用できます。
無理な勧誘は一切ない ので、お気軽にご参加ください。

今なら相談した方限定の割引・参加特典付き! 無料相談はこちら

select optionの背景色をつける方法

先ほどの都道府県名の選択式メニューに、CSSのbackgroundプロパティ(または、background-colorプロパティ)を使用して、背景色を設定してみましょう。

HTML:

<select name="住所">
  <option value="tokyo">東京都</option>
  <option value="kanagawa">神奈川県</option>
  <option value="chiba">千葉県</option>
  <option value="saitama">埼玉県</option>
  <option value="ibaraki">茨城県</option>
</select>

<select name="住所" size="5">
  <option value="tokyo">東京都</option>
  <option value="kanagawa">神奈川県</option>
  <option value="chiba">千葉県</option>
  <option value="saitama">埼玉県</option>
  <option value="ibaraki">茨城県</option>
</select>

CSS:

select{
  background:yellow;
}
option:first-child{
  background:green;
}

表示結果からわかるように、プルダウン型の選択式メニューにはoptionに背景色を指定することができません。
リスト型の選択式メニューは、select、optionともに背景色の指定が可能です。

 

実際に書いてみよう

今回はリスト型の選択式メニューについて、隔行で色を変えるカスタマイズ、行ごとに色を変えてカラフルにカスタマイズしてみます。

HTML:

<p>1行ごとに色を変える</p>
<select name="住所" size="5" id="s1">
<option value="tokyo">東京都</option>
<option value="kanagawa">神奈川県</option>
<option value="chiba">千葉県</option>
<option value="saitama">埼玉県</option>
<option value="ibaraki">茨城県</option>
</select>
<p>虹色にする</p>
<select name="住所" size="5" id="s2">
<option value="tokyo">東京都</option>
<option value="kanagawa">神奈川県</option>
<option value="chiba">千葉県</option>
<option value="saitama">埼玉県</option>
<option value="ibaraki">茨城県</option>
</select>

 

CSS:

/*奇数行の背景をライトグレーに*/
#s1 option:nth-child(2n+1){
background:lightgray;
}

/*1行ごとに色を設定*/
#s2 option:first-child{
background:red;
color:#fff;
}
#s2 option:nth-child(2){
background:orange;
}
#s2 option:nth-child(3){
background:yellow;
}
#s2 option:nth-child(4){
background:green;
color:#fff;
}
#s2 option:nth-child(5){
background:blue;
color:#fff;
}

 

 

CSSの疑似クラスを使用して、いろいろなリスト型の選択式メニューを作成することができました。
また<option>タグに、idやclassを設定して、CSSを適用したり、background以外のプロパティを適用することも可能です。

少しHTMLやCSSが複雑になりますが、プルダウン型の選択式メニューもCSSだけでカスタマイズすることができます。
ただし、<option>タグにあたる部分はCSSを適用することができません。

 

HTML:

<div class="selectbox">
  <select name="住所">
    <option value="tokyo">東京都</option>
    <option value="kanagawa">神奈川県</option>
    <option value="chiba">千葉県</option>
    <option value="saitama">埼玉県</option>
    <option value="ibaraki">茨城県</option>
  </select>
</div>
<div class="selectbox color">
  <select name="住所">
    <option value="tokyo">東京都</option>
    <option value="kanagawa">神奈川県</option>
    <option value="chiba">千葉県</option>
    <option value="saitama">埼玉県</option>
    <option value="ibaraki">茨城県</option>
  </select>
</div>

CSS:

.selectbox {
    width:90%;
    margin:1em auto;
  position:relative;
}
select{
  -webkit-appearance:none;
    appearance:none;
  width:100%;
  padding:1em 1em;
  box-sizing:border-box;
  font-size:1em;
  border:#ccc 1px solid;
  border-radius:0;
  background:#fff;
}
.selectbox::after{
  content:"";
  display:block;
  width:10px;
  height:10px;
  position:absolute;
  right:5%;
  top:35%;
  border-bottom:#333 2px solid;
  border-right:#333 2px solid;
  transform:rotate(45deg)translateY(-30%);
}
.color.selectbox select{
  background:blue;
  color:#fff;
  border-radius:2em;
}
.color.selectbox::after{
  border-bottom:#fff 5px solid;
  border-right:#fff 5px solid;
}

 

1時間でできる無料体験!

まとめ

今回は<select>タグと<option>タグをカスタマイズする方法について解説しました。
様々なカスタマイズを試してみてください。

 

執筆してくれたメンター

メンター 橋本真理

フリーのWeb/グラフィックデザイナー

会社・店舗・自治体などのWebサイトのデザインから制作一式、ロゴや各種広告などのグラフィックデザインを主に活動。テックアカデミーではWebデザインコース・WordPressコースを担当しています。

ラジオとバナナが好き。

 

大石ゆかり

内容が分かりやすくて良かったです!

田島悠介

ゆかりちゃんも分からないことがあったら質問してね!

大石ゆかり

分かりました。ありがとうございます!

CSSを学習中の方へ

これで解説は終了です、お疲れさまでした。

  • つまずかず「効率的に」学びたい
  • 副業や転職後の「現場で使える」知識やスキルを身につけたい

CSSを学習していて、このように思ったことはありませんか?

テックアカデミーのWebデザインコースでは、第一線で活躍する「プロのWebデザイナー」が教えているので、効率的に実践的なスキルを完全オンラインでしっかり習得できます。

合格率10%の選考を通過した、選ばれたWebデザイナーの手厚いサポートを受けながら、オリジナルのWebサイト制作を学べます。

まずは一度、無料体験で学習の悩みや今後のキャリアについて話してみて、「現役Webデザイナーから教わること」を実感してみてください。

時間がない方、深く知ってから体験してみたい方は、今スグ見られる説明動画から先に視聴することをおすすめします!

初心者・未経験でもできる。まずはテックアカデミーに相談しよう

プログラミングを独学で学習していて、このように感じた経験はないでしょうか?

  • ・調べてもほしい情報が見つからない
  • ・独学のスキルが実際の業務で通用するのか不安
  • ・目標への学習プランがわからず、迷子になりそう

テックアカデミーでは、このような 学習に不安を抱えている方へ、マンツーマンで相談できる機会を無料で提供 しています。
30分間、オンラインでどんなことでも質問し放題です。

「受けてよかった」と感じていただけるよう カウンセラーやエンジニア・デザイナー があなたの相談に真摯に向き合います。

「自分に合っているか診断してほしい」
「漠然としているが話を聞いてみたい」

こんなささいな悩みでも大丈夫です。

無理な勧誘は一切ありません ので、まずはお気軽にご参加ください。
※体験用のカリキュラムも無料で配布いたします。(1週間限定)

今なら参加者限定の割引特典付き! 無料相談を予約する