icon
icon

Ruby on Railsのf.selectの使い方を現役エンジニアが解説【初心者向け】

初心者向けにRuby on Railsのf.selectの使い方について現役エンジニアが解説しています。f.selectとは、Ruby on Railsでセレクトボックスなどの入力フォームを追加することができるものです。f.selectの書き方や使い方について解説します。

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

Ruby on Railsのf.selectの使い方について、TechAcademyのメンター(現役エンジニア)が実際のコードを使用して初心者向けに解説します。

 

Rubyについてそもそもよく分からないという方は、Rubyとは何なのか解説した記事を読むとさらに理解が深まります。

 

なお本記事は、TechAcademyのオンラインブートキャンプ、Ruby講座の内容をもとに紹介しています。
 

田島悠介

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

大石ゆかり

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

田島悠介

Ruby on Railsのf.selectの使い方について詳しく説明していくね!

大石ゆかり

お願いします!

 

目次

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

 

Railsのf.selectとは?

Webアプリケーションでは、入力フォームを作成することがよくあります。

f.selectは、Railsでその入力フォームの中にセレクトボックスを追加したい時に使います。f.selectは、Railsのヘルパーメソッドform_withと一緒に使います。
 

[PR] Rubyのプログラミングで挫折しない学習方法を動画で公開中

f.selectでできること

f.selectを使うと、セレクトボックスの選択項目や選択された時の値や、セレクトボックスに設定したいオプションを指定できます。

最終的には、HTMLのselectタグと関連タグが生成されます。Railsで定義したモデルを利用したセレクトボックスが簡単に作れます。
 

f.selectの書き方

f.selectは、

<%= f.select 属性, 選択肢の集合, {オプション}, {HTMLオプション} %>

と書くか、あるいは、

<%= f.select( 属性, 選択肢の集合, {オプション}, {HTMLオプション} ) %>

と括弧を使って書きます。
 

コラム

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

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

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

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

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

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

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

実際に書いてみよう

性別(sex)を持つuserモデルがあるとします。userにsexを選択して登録するフォームは、

 

<%= form_with(model: user, local: true) do |f| %>
  <div class="form-group">
    <%= f.label :sex, '性別' %>
    <%= f.select :sex, {'男性': 1, '女性': 2}, { include_blank: '選択してください'}, { class: 'form-control' , required: true } %>
  </div>

  <div class="form-group">
    <%= f.submit '送信', class: 'btn btn-primary btn-block' %>
  </div>
<% end %>

 

と書きます。

form_withからendまでがフォームです。userモデルのsexカラムに対して値を取得するためのフォームです。divはBootstrapで装飾した例です。divはなくても動作します。

セレクトボックスは、f.selectで用意します。f.labelは、セレクトボックスの項目名です。f.selectとf.labelは、同じ属性(この例では :sex)を指定することで、セレクトボックスを直接マウスでクリックしなくても、項目名をクリックしてセレクトボックスが選択可能になります。

f.selectの選択肢の集合は、

{'男性': 1, '女性': 2}

あるいは、

[['男性', 1], ['女性', 2]]

にように定義します。選択肢の情報は、ハッシュか配列で定義します。この例では、’男性’ か ‘女性’  の2択を定義したハッシュです。選択肢はもっと増やすこともできます。

'男性': 1

のように、1つの要素が1つの選択肢です。男性が選択されたら、1が設定されるという定義です。

オプションは、

{ include_blank: '選択してください' }

のようにします。この例では、何も選択されていない時は、 ‘選択してください’ という項目が選択されるという定義です。セレクトボックスの1番目の選択肢に ‘選択してください’ が追加されます。ユーザーが ‘選択してください’ を選択しても、何も選択されていないことになります。あくまで選択の注意を促すために使います。

include_blankを使わず、初期状態でどれかの項目を選択した状態にしたい場合には、オプションで

{selected: 2}

のようにします。この例では2の値を持つ 選択肢 ‘女性’ を選択した状態にできます。2ではなく1にすれば、男性を選択した状態にすることもできます。

最後のHTMLオプションは、

{ class: 'form-control' , required: true }

のようにします。HTMLタグとして追加したい属性を設定します。この例では、

class: 'form-control'

は、

class='form-control'

というHTMLタグを追加できます。Bootstrapなどのために何かclassを指定したい場合に使います。

required: true

は、

required='required'

というHTMLタグを追加できます。つまり、入力(選択)必須にできます。

最終的には、

<div class="form-group">
  <label for="user_sex">性別</label>
  <select prompt="選択してください" class="form-control" required="required" name="user[sex]" id="user_sex">
    <option value="">選択してください</option>
    <option selected="selected" value="1">女性</option>
    <option value="2">男性</option>
  </select>
</div>

が生成されます。※見やすいように整形してあります。
 

まとめ

f.selectを使うと、入力フォームにセレクトボックスを追加できます。

Webアプリケーションでセレクトボックスを使う機会は多いので、是非利用してみてください。
 

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

筆者プロフィール

伊藤広明(いとうひろあき)

1990年代からソフトウェア開発を仕事としてはじめ、2000年ごろからWEBエンジニアの仕事にも従事。
世の中で末長く使ってもらえるシステム開発が信条。後進の育成にも力を入れている。

作れるもの:Webシステム、スマホアプリ
書ける言語: Ruby・PHP・Python・Java・Swift・C#・C/C++・JavaScriptなど
経験があるフレームワーク: Laravel・Ruby on Rails・Apache Strutsなど

 

大石ゆかり

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

田島悠介

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

大石ゆかり

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

 

TechAcademyでは、初心者でも、Ruby on Railsを使ったプログラミングを習得できる、オンラインブートキャンプを開催しています。

また、現役エンジニアから学べる無料体験も実施しているので、ぜひ参加してみてください。

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

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

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

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

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

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

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

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

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