rails 3.2 ajax live search

时间:2013-02-22 19:51:06

标签: ruby-on-rails ajax

我仍然是一名Rails-Learner并且非常渴望实现ajax实时搜索。搜索似乎适用于提交,但不适用于密钥。无法弄清楚为什么......

index.html.erb

<%= form_tag contacts_path, :method => 'get', :id => "contacts_search" do %>
  <p>
    <%= text_field_tag :search, params[:search] %>
    <%= submit_tag "Search", :name => nil %>
  </p>
  <div id="cresults_div"><%= render 'cresults' %></div>
<% end %>

<%= link_to 'New Contact', new_contact_path %>

contacts_controller.rb

  def index
    @contacts = Contact.search(params[:search])

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @contacts }
    end
  end

index.js.erb的

$("#cresults_div").html("<%= escape_javascript(render("cresults")) %>");

contact.rb

  def self.search(search)
      if search
        where('last_name LIKE ?', "%#{search}%")
      else
        scoped
      end
  end

contacts.js.coffee

jQuery ->
  # Ajax search on submit
  $('#contacts_search').submit( ->
    $.get(this.action, $(this).serialize(), null, 'script')
    false
  )
  # Ajax search on keyup
  $('#contacts_search input').keyup( ->
    $.get($("#contacts_search").attr("action"), $("#contacts_search").serialize(), null, 'script')
    false
  )

_cresults.html.erb

<%= hidden_field_tag :direction, params[:direction] %>
<%= hidden_field_tag :sort, params[:sort] %>
<h1>Listing contacts</h1>

<table>
  <tr>
    <th>Salutation</th>
    <th>First name</th>
    <th>Last name</th>
    <th>Stree</th>
    <th>Street no</th>
    <th>Zip</th>
    <th>City</th>
    <th>State</th>
    <th>Country</th>
    <th>Phone</th>
    <th>Email</th>
    <th></th>
    <th></th>
    <th></th>
  </tr>

<% @contacts.each do |contact| %>
  <tr>
    <td><%= contact.salutation %></td>
    <td><%= contact.first_name %></td>
    <td><%= contact.last_name %></td>
    <td><%= contact.stree %></td>
    <td><%= contact.street_no %></td>
    <td><%= contact.zip %></td>
    <td><%= contact.city %></td>
    <td><%= contact.state %></td>
    <td><%= contact.country %></td>
    <td><%= contact.phone %></td>
    <td><%= contact.email %></td>
    <td><%= link_to 'Show', contact %></td>
    <td><%= link_to 'Edit', edit_contact_path(contact) %></td>
    <td><%= link_to 'Destroy', contact, confirm: 'Are you sure?', method: :delete %></td>
  </tr>
<% end %>
</table>

还试图额外添加 的application.js

$(function() {
  $("#contacts_search input").keyup(function() {
    $.get($("#contacts_search").attr("action"), $("#contacts_search").serialize(), null, "script");
    return false;
  });
});

但实时搜索不会在打字时开始......为什么?

1 个答案:

答案 0 :(得分:1)

在这种特殊情况下,我不得不删除

respond_to do |format|
  format.html # index.html.erb
  format.json { render json: @contacts }
end

阻止来自联系人控制器中的索引方法