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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails 5

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

Q&A

解決済

1回答

1433閲覧

checkboxで取得した複数の値を、一つのフィールドに保存する方法を教えてください

morimi714

総合スコア24

Ruby on Rails 5

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

0グッド

0クリップ

投稿2019/04/23 05:26

編集2019/04/24 09:34

rails初心者です。
DBはmySQLを使っています。

チェックボックスで複数選択をしても、最後の値しかデータベースに入っていない状況です。
例えばsat4,sun4という形で表示されて欲しいのにデータベースにはsun4しか表示されていません。

checkboxで取得した複数の値を、一つのフィールドに保存する方法を教えてください。

teachers/edit.html.erb

<table> <tr> <td>曜日/時間</td> <td>月曜</td> <td>火曜</td> <td>水曜</td> <td>木曜</td> <td>金曜</td> <td>土曜</td> <td>日曜</td> </tr> <tr> <td>午前中</td> <td><input type="checkbox" name="time[]" value="mon1"></td> <td><input type="checkbox" name="time[]" value="tue1"></td> <td><input type="checkbox" name="time[]" value="wed1"></td> <td><input type="checkbox" name="time[]" value="thu1"></td> <td><input type="checkbox" name="time[]" value="fri1"></td> <td><input type="checkbox" name="time[]" value="sat1"></td> <td><input type="checkbox" name="time[]" value="sun1"></td> </tr> <tr> <td>13:00~16:00</td> <td><input type="checkbox" name="time[]" value="mon2"></td> <td><input type="checkbox" name="time[]" value="tue2"></td> <td><input type="checkbox" name="time[]" value="wed2"></td> <td><input type="checkbox" name="time[]" value="thu2"></td> <td><input type="checkbox" name="time[]" value="fri2"></td> <td><input type="checkbox" name="time[]" value="sat2"></td> <td><input type="checkbox" name="time[]" value="sun2"></td> </tr> <tr> <td>16:00~19:00</td> <td><input type="checkbox" name="time[]" value="mon3"></td> <td><input type="checkbox" name="time[]" value="tue3"></td> <td><input type="checkbox" name="time[]" value="wed3"></td> <td><input type="checkbox" name="time[]" value="thu3"></td> <td><input type="checkbox" name="time[]" value="fri3"></td> <td><input type="checkbox" name="time[]" value="sat3"></td> <td><input type="checkbox" name="time[]" value="sun3"></td> </tr> <tr> <td>19:00~22:00</td> <td><input type="checkbox" name="time[]" value="mon4"></td> <td><input type="checkbox" name="time[]" value="tue4"></td> <td><input type="checkbox" name="time[]" value="wed4"></td> <td><input type="checkbox" name="time[]" value="thu4"></td> <td><input type="checkbox" name="time[]" value="fri4"></td> <td><input type="checkbox" name="time[]" value="sat4"></td> <td><input type="checkbox" name="time[]" value="sun4"></td> </tr> </table>
def new @teacher = Teacher.new end def show @teacher = Teacher.find_by(id: params[:id]) end def create @teacher = Teacher.new(teacher_params) if @teacher.save flash[:notice] = "家庭教師登録が完了しました" redirect_to("/teachers/#{@teacher.id}") else render("teachers/new") end end def edit @teacher = Teacher.find_by(id: params[:id]) end # updateアクションを作成してください def update @teacher = Teacher.find_by(id: params[:id]) if params[:image] @teacher.img = "#{@teacher.id}.jpg" image = params[:image] File.binwrite("public/teacher_images/#{@teacher.img}", image.read) end if @teacher.update(teacher_params) flash[:notice] = "ユーザー情報を編集しました" redirect_to("/teachers/#{@teacher.id}") else flash[:notice] = "編集できませんでした" render("teachers/edit") end end def login_form end def login @teacher = Teacher.find_by(email: params[:email]) if @teacher && @teacher.authenticate(params[:password]) session[:teacher_id] = @teacher.id flash[:notice] = "ログインしました" redirect_to("/") else @error_message = "メールアドレスまたはパスワードが間違っています" @email = params[:email] @password = params[:password] render("teachers/login_form") end end def logout session[:teacher_id] = nil flash[:notice] = "ログアウトしました" redirect_to("/login") end # ensure_correct_userを定義してください def ensure_correct_teacher if @current_teacher.id != params[:id].to_i flash[:notice] = "権限がありません" redirect_to("/") end end private def teacher_params params.permit(:name, :email, :password, :nickname, :gender, :university, :wage, :trafficwage, :time, :prefecture, :region, :profile, :message) end end

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ちょっと全体的にぼやっとしててわかりにくいんですが、controllerでどんな処理をしているのか?
paramsの中身に何が入っているのか?等、やったことをもう少し詳しく書いていただけるとわかりやすいかなと思います。

本題ですが、chekboxのnameがすべて同じになっているので、最後にチェックした値しかパラメータとしてcontrollerには飛んでないのではないでしょうか??

viewからcontrollerへチェックしたもの全て渡したいのであれば、
nameを一意にして上げれば飛ぶはずです。

追記

すみません、説明が悪かったです。
一つ例として<td><input type="checkbox" name="time[day_of_the_week][]" value="mon1"></td>のような感じで、全てのinputでnameをこの形に変更してください。

そして、コントローラのdef teacher_params を以下のようにします。

def teacher_params params.permit(:name, :email, :password, :nickname, :gender, :university, :wage, :trafficwage, time: [], :prefecture, :region, :profile, :message) end

すると、 teache_paramsのtime内にチェックした値全てが入るかと思います

投稿2019/04/24 09:25

編集2019/04/24 10:07
mot93

総合スコア99

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

morimi714

2019/04/24 09:36

すみません、情報不足だったため、コントローラーの中身を追加しました。おっしゃっているのは、:nameだけではいけないということでしょうか??
mot93

2019/04/24 10:07

コードを書いたので上記に追記しております 確認してみてくださいー
morimi714

2019/04/24 10:35

回答ありがとうございます!試してみたのですがコントローラ内の time: [] ですとsyntax errorとなったので:time[]と直したのですが、それだとargument errorとなり引数に何も入っていない状態になってしまうそうです・・・(T . T) でもちゃんとリクエストに"time"=>{"day_of_the_week"=>["sat4", "sun4"]},と入っています
mot93

2019/04/24 11:40

すみません。 permit時にtime: []を一番最後にする必要がありました。
morimi714

2019/04/25 01:23

解決しました^^ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問