plansモデルにあるカラムをhomeモデルで検索して、plansに表示したいと思っています。しかし、homeで検索する時に、うまくplansのカラムを集めることができていないか・homeからplansの受け渡しができていないなのかがわからない状態になっています。(homeモデルで、plansのtitleを検索して、検索後、plansモデルで表示できるようにしようと思っています)
わかる方がいらしたら、どうぞ教えていただきたいです。
期待していた挙動は、検索機能を利用して、homeのモデルからplansのtitleカラムを検索して、plansのviewで検索結果を表示していました。問題のある現在の挙動は、home/searchから検索するとhttp://localhost:3000/plans?utf8=✓&title=kobeと検索されているのですが、結果が出せていない。
app/views/home/search.html.erb
app/views/plans/index.html.erb
app/controllers/plans_controller
controller
1 def index 2 @plans = Plan.includes(:guider).page(params[:page]).per(5).order("created_at DESC") 3 @plans = Plan.page(params[:page]).per(5).order("created_at DESC").search(params[:search]) 4 end 5 6 def create 7 Plan.create(place: params[:place], image: params[:image], copy_image: params[:copy_image], second_image: params[:second_image], third_image: params[:third_image], fourth_image: params[:fourth_image], five_image: params[:five_image], title: params[:title], contents: params[:contents], times: params[:times], datetimes: params[:datetimes], guider_id: current_guider.id 8 end
app/controller/home_controller
controller
1 def search 2 @plans = Plan.includes(:guider).page(params[:page]).per(5).order("created_at DESC") 3 @plans = Plan.page(params[:page]).per(5).order("created_at DESC").search(params[:search]) 4 end
app/model/home.rb
model
1 class Home < ActiveRecord::Base 2 belongs_to :plan 3 4 def self.search(search) 5 if search 6 Plan.where(['title LIKE ?', "%#{search}%"]) 7 else 8 Plan.all 9 end 10 end 11 end
db/migrate/plans
1 class CreatePlans < ActiveRecord::Migration 2 def change 3 create_table :plans do |t| 4 t.text :title 5 t.timestamps null: false 6 end 7 end 8end
app/views/home/search.html.erb
view
1 <%= form_tag plans_path, :method => 'get', :class => 'search' do %> 2 <p class="search_answer"><%= text_field_tag "title", "", class: "question" %> 3 <%= submit_tag "Search", :name => nil, class: "answer" %></p> 4 <% end %>
回答1件
あなたの回答
tips
プレビュー