我已经设法(通过这个论坛)搜索了多个带有太阳黑子的模型。现在我被困在如何以预期的方式显示结果。
这是我的控制器中的内容
@search = Sunspot.search [Gear, User] do
fulltext params[:search]
paginate(page: params[:page])
end
@gears = @search.results
所以在我添加 User 模型之前,我会遍历每个 Gear 对象,如下所示:
<% @gears.each do |gear| %>
<%= link_to gear_path(gear) do %>
<div class="gear_list_box">
<div class="gear_list_box_top"><%= image_tag gear.image_url(:list), class: 'gear_list_box_top_pic' %></div>
<div class="gear_list_box_bottom">
<table style="border-collapse:collapse; cellspacing: 0; width: 100%; margin: 0;" >
<tr>
<td style="color: #2c6aa7; padding-left: 10px" width="60%"> <span class='gearlist_size'><%= gear.size %></span> - <%= truncate(gear.title,:length => 12) %></td>
<td rowspan="2" width="40%" style="color: #5c8d0d; text-align: center; vertical-align: middle; font-size: 120%; border-collapse:collapse;">$<%= gear.price %>/day</td>
</tr>
<tr>
<td width="60%" style="padding-left: 10px; font-size: 12px;"><%= gear.user.first_name + " " + gear.user.last_name%></td>
</tr>
</table>
</div>
</div>
<% end %>
<% end %>
现在它通过类似于以下的错误:
NoMethodError in Gears#index
Showing /Users/dave/rails_projects/outdoor/app/views/gears/_gear.html.erb where line #3 raised:
undefined method `image_url' for #<User:0x007fd6654cae08>
因为 User 对象显然没有与 Gear 对象相同的列。如何正确显示此内容并仍按用户名搜索?
模型是 Gear:belongs_to User:has_many
谢谢你。