質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.46%

  • Ruby on Rails

    9113questions

    Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

  • Ruby on Rails 4

    2552questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

複数選択をcheck_boxで作成する場合、modelを分けるか、同じtable内で処理するべきか

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 825

innjera

score 117

添付画像の様に、複数選択をcheck_boxで作成する場合、(A)基本となるmodel内の同一のtable内で処理するやり方と、複数選択に該当する部分のみ(B)別modelにする方法があるかと思います。

初心者であるため、どちらとするべきか分からず、ご意見をお伺いしたく、宜しくお願い致します。

以下コードに記載の通り、(A)ではformが肥大化且つ繰り返しが続き見通し悪くなることから、なんとなく(B)別modelにする方法が良い気がするしています。

一方、(B)別modelにする場合、modelの数が増えることや、選択肢をseed.rbファイルで入れており、不便な気がしております。選択肢をmodel内に定義するやり方はあるのでしょうか?。(質問が2つになってしまっておりすいません)

イメージ説明

前提

Lesson modelが各々ジャンル(genre)を複数持っている。

実際のコード

(A)元のmodel(Lesson Model)内の同一のtable内で処理するやり方

#Lessonのtable
#  id                :integer          not null, primary key
#  title             :string
#  genre              :string
#  created_at        :datetime         not null
#  updated_at        :datetime         not null

#Lesson Model
class Lesson < ApplicationRecord
  before_save do
    self.genre.gsub!(/[\[\]\"]/, "") if attribute_present
("genre")
  end
end

#controller
省略し、strong parameterのみ
private def lesson_params
  attrs = [:id, :title, genre:[]]
    params.require(:lesson).permit(attrs)
end

#lessons_helper.rb
module LessonsHelper
  def checked_genre(area)
    @lesson.genre.nil? ? false : @lesson.genre.match(area)
  end
end

#_form.html.erb
<%= f.label :genre, 'ジャンル' %>
<%= check_box_tag 'lesson[genre][]', 'OL', checked_genre('OL'), id: 'genre_ol'%>
<%= label_tag 'genre_ol', 'OL' %>
これを何個も書く

(B)別modelにする方法

#Lessonのtable
id                :integer          not null, primary key
title             :string
created_at        :datetime         not null
updated_at        :datetime         not null

#Lesson Model
class Lesson < ApplicationRecord
  has_and_belongs_to_many :genres
end

#Genreのtable
id         :integer          not null, primary key
name       :string
created_at :datetime         not null
updated_at :datetime         not null

#Genre Model
class Genre < ApplicationRecord
  has_and_belongs_to_many :lessons
end

#controller
省略し、strong parameterのみ
private def lesson_params
  attrs = [:id, :title,  genre_ids:[]]
    params.require(:lesson).permit(attrs)
end

#seeds.rb
areas_of_genres = %w(OL 清楚 キャバ嬢 ギャル 特殊メイク コスプレ ハロウィン)

areas_of_genres.each do |name|
  Genre.create(name: name)
end

#_form.html.erb
<%= f.label "ジャンル" %>
<%= f.collection_check_boxes :genre_ids, Genre.all, :id, :name do |b| %>
 <%= b.check_box %>
  <%= b.label %>&nbsp
   <% end %>
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.46%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Ruby on Rails

    9113questions

    Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

  • Ruby on Rails 4

    2552questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。