現在個人でWEBサービスを開発している者です。
◾️やりたいこと
railsで、accepts_nested_attributes_forを使って子モデルも一緒に保存したい
◾️課題
入力フォームに値を入れてsubmitしてもDBに値が保存されない
(エラー等が起きるわけでもなく、画面もしない)
お手数ですが、有識者の皆様のお力添えいただけますと幸いです。
サイト等みながら色々と試してみた関係で、
不要なコードやDB項目が含まれているかもしれませんがご了承ください。
また、不足している情報があればお出ししますのでご教示ください。
◾️テーブル一覧
概要:ユーザー(user)が、プラン名(plan)を投稿します。同時にnested modelのプラン詳細(posts)を登録するというイメージです。
例:ユーザ1(user)が箱根1泊旅行(plan)と同時に時間等(posts)を登録
users:
("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "name" varchar, "email" varchar, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL, "image_name" varchar, "password_digest" varchar);
plans:
("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "plan_name" varchar, "user_id" integer, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL);
posts:
("id" INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, "content" text, "created_at" datetime NOT NULL, "updated_at" datetime NOT NULL, "user_id" integer, "plan_id" integer, "plan_date" varchar, "arrival_time" varchar, "place_image" varchar, "place_name" varchar);
◾️ソース一覧
★plan.rb
class Plan < ApplicationRecord validates :user_id, {presence: true} belongs_to :user has_many :posts accepts_nested_attributes_for :posts end
★post.rb
class Post < ApplicationRecord validates :user_id, {presence: true} belongs_to :plan def user return User.find_by(id: self.user_id) end end
★user.rb
class User < ApplicationRecord has_secure_password validates :email,{uniqueness: true} validates :password,{presence: true} has_many :plans has_many :posts def posts return Post.where(user_id: self.id) end end
★/app/views/plans/new.html.erb
<div class="main posts-new"> <div class="container"> <h1 class="form-heading">プランを作成する</h1> <%= form_for @plan,:url => {:controller => :plans ,:action => :create} do |f| %> <div class="form"> <div class="form-body"> <div class="field"> <%= f.label :プラン名 %><br> <%= f.text_field :plan_name %> </div> <div class="field"> <%= f.label :posts, "プラン詳細" %><br /> <%= f.fields_for :posts do |posts_form| %> <%= posts_form.hidden_field :user_id, value: @current_user.id %> <%= posts_form.label :日付 %> <%= posts_form.date_field :plan_date %><br /> <%= posts_form.label :到着時間 %> <%= posts_form.time_field :arrival_time %><br /> <%= posts_form.label :地名 %> <%= posts_form.text_field :place_name %><br /> <%= posts_form.label :やること %> <%= posts_form.text_field :content %><br /> <% end %> </div> <%= f.submit "作成" %> </div> <% end %> </div>
★/app/controllers/plans_controller.rb
class PlansController < ApplicationController before_action :authenticate_user def create @plan = Plan.create(plan_params) if @plan.save flash[:success] = "投稿が完了しました!" redirect_to("/posts/index") else flash.now[:alert] = "投稿が失敗しました。" #render end end def new @plan = Plan.new @plan.posts.build end private def plan_params params.require(:plan).permit( :plan_name, :prefecture_id, posts_attributes: [:id, :plan_id, :user_id, :plan_date, :arrival_time, :place_name, :place_image, :content, :_destroy] ).merge(user_id: @current_user.id) end end
★route.rb
Rails.application.routes.draw do post 'users/create' => 'users#create' get "signup" => "users#new" get 'users/index' => 'users#index' get 'users/:id' => 'users#show' get 'users/:id/edit' => 'users#edit' get 'users/:id/likes' => 'users#likes' post 'users/:id/update' => 'users#update' post 'users/:id/destroy' => 'users#destroy' get 'login' => 'users#login_form' post 'login' => 'users#login' post 'logout' => 'users#logout' get 'posts/index' => 'posts#index' get 'posts/new' => 'posts#new' get 'posts/:id' => 'posts#show' post 'posts/create' => 'posts#create' get 'posts/:id/edit' => 'posts#edit' post 'posts/:id/update' => 'posts#update' post 'posts/:id/destroy' => 'posts#destroy' get 'plans/new' => 'plans#new' post 'plans/create' => 'plans#create' get '/' => 'home#top' get '/about' => 'home#about' # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html end
回答1件
あなたの回答
tips
プレビュー