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

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,644

pecchan

score 267

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

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

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

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

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

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

エラー画面

@@@コントローラ

class ProductsController < ApplicationController

  def index

    @q = Product.search

  end

  def search

        if params.nil?

        @q = Product.search(search_params)

        @products = @q
          .result
          .order(availability: :desc, code: :asc)
          .decorate

        else

            @q = Product.search

            @products = @q

        end



  end

  private

  def search_params
    search_conditions = %i(
      code_cont name_cont name_kana_cont availability_true
      price_gteq price_lteq purchase_cost_gteq purchase_cost_lteq
    )
    params.require(:q).permit(search_conditions)
  end

end

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

<% content_for(:title) do %>
  <h1>商品検索</h1>
<% end %>




    <%= search_form_for(@q, url: search_products_path, html: { method: :get, class: 'form-horizontal', role: 'form' }) do |f| %>
      <%= render 'search_form', f: f %>
    <% end %>


<%= render layout: 'shared/search_result_box' do %>
  <table class="table table-list ">
  <thead>
    <tr>
      <th>販売状況</th>
      <th>商品コード</th>
      <th>商品名</th>
      <th>販売価格</th>
      <th>仕入原価</th>
    </tr>
  </thead>

    <p>カウント:<%= @products.count %></p>
    <% @products.each do |product| %>
      <tbody>
      <tr>
        <td><%= product.sales_condition %> </td>
        <td><%= product.code %></td>
        <td><%= product.name %></td>
        <td><%= product.display_price %></td>
        <td><%= product.display_purchase_cost %></td>
      </tr>
      </tbody>
    <% end %>


    </table>

<% end %>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

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

 else

            @q = Product.search

            @products = @q.result

        end


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

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/04/28 14:32 編集

    あぁぁぁぁ 
    1から10まですみません。
    やっぱり解決できずにおりました(;_;)
    有難う御座います!

    search_params(ストロングパラメータ)が使えないかわりに、
    column_names + _ransackers.keysを使うってことでしょうか?!

    キャンセル

  • 2017/04/28 14:46

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

    キャンセル

  • 2017/04/28 14:52

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

    キャンセル

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

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