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

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

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

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

Q&A

解決済

1回答

3930閲覧

【Ruby on Rails】検索画面を1つの画面で実装したい

pecchan

総合スコア555

Ruby on Rails

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

0グッド

0クリップ

投稿2017/04/27 06:27

Ransackを使った検索画面のサンプルがあります。
http://rails.densan-labs.net/form/search_form.html

上記では検索画面(index)と、結果画面(search)が別です。

これを1つの画面(html)にしたいです。

検索画面側は、検索フォームのみ
結果画面側は、検索フォーム+結果表示部分
で構成されています。

今回は、searchの方だけで実現しようと以下のようにしましたが、
NoMethodErrorで怒られ初期表示できません。

すみませんがご教示いただけないでしょうか?
宜しくお願い致します。

エラー画面

@@@コントローラ

ruby

1class ProductsController < ApplicationController 2 3 def index 4 5 @q = Product.search 6 7 end 8 9 def search 10 11 if params.nil? 12 13 @q = Product.search(search_params) 14 15 @products = @q 16 .result 17 .order(availability: :desc, code: :asc) 18 .decorate 19 20 else 21 22 @q = Product.search 23 24 @products = @q 25 26 end 27 28 29 30 end 31 32 private 33 34 def search_params 35 search_conditions = %i( 36 code_cont name_cont name_kana_cont availability_true 37 price_gteq price_lteq purchase_cost_gteq purchase_cost_lteq 38 ) 39 params.require(:q).permit(search_conditions) 40 end 41 42end

@@@@ビュー
下記の<p>カウント:<%= @products.count %></p>でエラー

ruby

1<% content_for(:title) do %> 2 <h1>商品検索</h1> 3<% end %> 4 5 6 7 8 <%= search_form_for(@q, url: search_products_path, html: { method: :get, class: 'form-horizontal', role: 'form' }) do |f| %> 9 <%= render 'search_form', f: f %> 10 <% end %> 11 12 13<%= render layout: 'shared/search_result_box' do %> 14 <table class="table table-list "> 15 <thead> 16 <tr> 17 <th>販売状況</th> 18 <th>商品コード</th> 19 <th>商品名</th> 20 <th>販売価格</th> 21 <th>仕入原価</th> 22 </tr> 23 </thead> 24 25 <p>カウント:<%= @products.count %></p> 26 <% @products.each do |product| %> 27 <tbody> 28 <tr> 29 <td><%= product.sales_condition %> </td> 30 <td><%= product.code %></td> 31 <td><%= product.name %></td> 32 <td><%= product.display_price %></td> 33 <td><%= product.display_purchase_cost %></td> 34 </tr> 35 </tbody> 36 <% end %> 37 38 39 </table> 40 41<% end %>

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

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

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

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

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

guest

回答1

0

ベストアンサー

else以降の@productsが
ransack::searchobjectのままです。
resultをつけてActiveRecord::Relationに戻しましょう

ruby

1 else 2 3 @q = Product.search 4 5 @products = @q.result 6 7 end 8

あと、好みの域をでないのですが
できればindexの方だけで実現した方が...
indexはデフォルトで
def search は余計なrouteを追加することに他ならないので

投稿2017/04/27 08:49

編集2017/04/27 08:56
moke

総合スコア2241

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

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

pecchan

2017/04/28 01:51 編集

moke様 いつも有難う御座います。 また基礎的な部分が足りないなぁと痛感しました(泣) Product.searchで受けたのでresultで返す!ですね。 ※ちょっと調べました あとデコレーションしてるのでdecorateも追加しました。 今は、おかげ様でエラーは出なくなりましたが、何故か検索条件が渡らないようになったので 調べています! 有難う御座いました! あ!完成したらsearch→indexに変えようと思ってました^^
moke

2017/04/28 01:56 編集

えっ検索条件をあえて渡さない処理なのでは? 意図した動きと異なるというのなら if文が逆ですよ if params.present? にするのが正しいのでは? デフォルトの検索条件をつけないor他で定義するなら いっそのことif文を取ってしまえばいいと思いますが
pecchan

2017/04/28 01:54

でした! すいません。。。 いっそif分を無くしました。 有難う御座いました!
pecchan

2017/04/28 02:03

今からアクションをindexに変えるのと、 1つの入力でコード、名前、仮名などを検索できるようにしてみます!!
pecchan

2017/04/28 02:32

ifで分岐したのは、 (serachでもindexでも同じですが)1画面にした場合、検索前の初期表示時、 paramsの:qで「param is missing or the value is empty: q」と怒られるからでした(^^;) なので1画面にした際、ifでparamsを見てました。 でも何か違う気はしてました・・・orz
moke

2017/04/28 02:58 編集

require(:q)にしてましたか だと、エラーが出ますね…。 一応こういうのがあるのですが、まあ、わかりやすい方を設定してください。 # `ransackable_attributes` by default returns all column names # and any defined ransackers as an array of strings. # For overriding with a whitelist array of strings. # def ransackable_attributes(auth_object = nil) column_names + _ransackers.keys end # `ransackable_associations` by default returns the names # of all associations as an array of strings. # For overriding with a whitelist array of strings. # def ransackable_associations(auth_object = nil) reflect_on_all_associations.map { |a| a.name.to_s } end
pecchan

2017/04/28 03:45

moke様 度々有難う御座います。 Productモデルに追加したのですが同じエラーになります。。。
moke

2017/04/28 03:56

search_params の代わりにparams[:q] を使うプランの話です。
pecchan

2017/04/28 04:34

moke様 度々すみません、有難う御座います。 コントローラの @q = Product.search(search_params) を @q = Product.search(params) に変更しました。 初期表示は出来るようになりましたが、検索しても何も表示されなくなりました。 1つ1つ調べてます。 申し訳ございません。
moke

2017/04/28 05:25

@q = Product.search(params[:q]) ですよ
pecchan

2017/04/28 05:37 編集

あぁぁぁぁ  1から10まですみません。 やっぱり解決できずにおりました(;_;) 有難う御座います! search_params(ストロングパラメータ)が使えないかわりに、 column_names + _ransackers.keysを使うってことでしょうか?!
moke

2017/04/28 05:46

そちらの方が見通しがよくなると思います。 まあ、好みの問題ですが。 特にassosiationやsortに関してもあるので、より細かく設定できると思います。
pecchan

2017/04/28 05:52

ストロングパラメータ(最近知ったばかり)しかないと思ってました(*_*) 色んな方法があるんですね。 仰る通り見通しが良くて好きです! 有難う御座いました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問