Rails 5 个搜索问题

Rails 5 issue with doing a search

我在这个问题上花了将近一天的时间,但似乎无法弄清楚。我的 index.html.erb 页面上有一个表格,用于搜索并看起来像这样:

<%= form_with(url: "/search", method: "get") do |f| %>

    <%= f.label :Start_date %>
    <%= f.date_select :date_out %>

    <%= f.label :End_Date %>
    <%= f.date_select :endDate %>
    
    <br>
    <p>Enter Report Type:</p>
    <%= select_tag :reportType,
      options_for_select([['sale', 'sale'], ['received', 'received'], ['po', 'po'], ['invoice', 'invoice']]) %>
    <br>

    <%= submit_tag("Show Report") %>

  <% end %>

在我的控制器中,我有一个如下所示的搜索操作:

class ItemInstancesController < ApplicationController
  def search
    # Converting the string params to a Date
    startDate = Date.new(params["date_out(1i)"].to_i, params["date_out(2i)"].to_i, params["date_out(3i)"].to_i)
    endDate = Date.new(params["endDate(1i)"].to_i, params["endDate(2i)"].to_i, params["endDate(3i)"].to_i)

    # Getting the params from what the user submitted 
    reportType = params[:reportType]

    if reportType == 'po'
      
      # I have to do a search of the item_instances model to pull based on the date range of the date_out column 
      @item_instances = ItemInstance.search_for_records_by_date(startDate, endDate).order("po_number ASC")
      format.html { render :search }
    end 

  end 
end

问题是我在点击表单时没有进入搜索页面。我可以看到我的参数很好。这是我点击显示报告按钮时在终端中看到的内容:

Started GET "/search?utf8=%E2%9C%93&%5Bdate_out(1i)%5D=2020&%5Bdate_out(2i)%5D=8&%5Bdate_out(3i)%5D=11&%5BendDate(1i)%5D=2020&%5BendDate(2i)%5D=8&%5BendDate(3i)%5D=11&reportType=po&commit=Show%20Report" for 10.9.0.201 at 2020-08-11 15:40:00 -0400
Cannot render console from 10.9.0.201! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by ItemInstancesController#search as JS
  Parameters: {"utf8"=>"✓", "date_out(1i)"=>"2020", "date_out(2i)"=>"8", "date_out(3i)"=>"11", "endDate(1i)"=>"2020", "endDate(2i)"=>"8", "endDate(3i)"=>"11", "reportType"=>"po", "commit"=>"Show Report"}
2020-08-11
2020-08-11
po
  ItemInstance Load (0.4ms)  SELECT `item_instances`.* FROM `item_instances` WHERE `item_instances`.`date_out` BETWEEN '2020-08-11' AND '2020-08-11' ORDER BY po_number ASC
  ↳ app/controllers/item_instances_controller.rb:28
#<ItemInstance:0x00007f06bc1209e8>
#<ItemInstance:0x00007f06bc1208a8>
Completed 500 Internal Server Error in 3ms (ActiveRecord: 0.4ms)


  
ArgumentError (too few arguments):
  
app/controllers/item_instances_controller.rb:29:in `format'
app/controllers/item_instances_controller.rb:29:in `search'

我也不知道为什么我的表单被处理为 JS 而不是 HTML。当我提交表单时,网页上没有任何反应 - 这意味着它停留在 index.html.erb 上。最后,我的路线如下所示:

Rails.application.routes.draw do
  resources :item_instances
  get '/search', to: 'item_instances#search'

  resources :items

  # Route to the home page 
  root 'home#index'
  
  # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html
end

模型是这样的:

  create_table "item_instances", options: "ENGINE=InnoDB DEFAULT CHARSET=latin1", force: :cascade do |t|
    t.integer "inv_number"
    t.string "serial"
    t.integer "po_number"
    t.date "po_date"
    t.date "invoice"
    t.date "date_out"
    t.decimal "cost", precision: 8, scale: 2
    t.string "acro"
    t.datetime "created_at", null: false
    t.datetime "updated_at", null: false
    t.bigint "item_id"
    t.index ["item_id"], name: "fk_rails_6ea33fd9d0"
  end

感谢您提供的任何帮助。

这是 index.html.erb 文件:

<p id="notice"><%= notice %></p>

<h1>Item Instances</h1>

<table>
  <thead>
    <tr>
      <th>Inv number</th>
      <th>Description</th>
      <th>Serial</th>
      <th>PO number</th>
      <th>PO date</th>
      <th>Invoice</th>
      <th>Date Out</th>
      <th>Cost</th>
      <th>Acro</th>
      <th colspan="3"></th>
    </tr>
  </thead>

  <tbody>
    <% @item_instances.each do |item_instance| %>
      <tr>
        <td><%= item_instance.inv_number %></td>
        <td><%= link_to item_instance.item.description, edit_item_instance_path(item_instance)%></td>
        <td><%= item_instance.serial %></td>
        <td><%= item_instance.po_number %></td>
        <td><%= item_instance.po_date %></td>
        <td><%= item_instance.invoice %></td>
        <td><%= item_instance.date_out %></td>
        <td><%= item_instance.cost %></td>
        <td><%= item_instance.acro %></td>
        <td><%= link_to 'Show', item_instance %></td>
        <td><%= link_to 'Edit', edit_item_instance_path(item_instance) %></td>
        <td><%= link_to 'Destroy', item_instance, method: :delete, data: { confirm: 'Are you sure?' } %></td>
      </tr>
    <% end %>
  </tbody>
</table>

<br>


<%= form_with(url: "/search", method: "get") do |f| %>

    <%= f.label :Start_date %>
    <%= f.date_select :date_out %>

    <%= f.label :End_Date %>
    <%= f.date_select :endDate %>
    
    <br>
    <p>Enter Report Type:</p>
    <%= select_tag :reportType,
      options_for_select([['sale', 'sale'], ['received', 'received'], ['po', 'po'], ['invoice', 'invoice']]) %>
    <br>

    <%= submit_tag("Show Report") %>

  <% end %>

<%= link_to 'New Item Instance', new_item_instance_path %>

这是 search.html.erb 页面:(此时我只想让页面显示标题)

<h1>Report Page</h1>

你的 format 必须在 respond_to 块内

respond_to do |format| 
  format.html { render :search }
end

或者你可能只需要

render :search

form_with 的默认设置是远程发送您的表单。这就是您看到 Processing by ItemInstancesController#search as JS 的原因。如果您将 local: true 添加到您的表单,您应该在您的控制器中点击 format.html。您可以阅读更多关于 form_with here.