2

我的应用程序有一个 habtm 关系 b/w 列表和类别。现在从类别索引页面,用户过滤选择框以查看显示页面中的列表。

现在我无法访问附加到类别显示页面中列表的图像。

清单.rb

attr_accessible :placeholder, :categories_ids

  has_and_belongs_to_many :categories
  has_attached_file :placeholder, :styles => { :medium => "300x300>", :thumb => "100x100>" }, :default_url => "/images/:style/missing.png",
                      :url => "/system/:hash.:extension",
                     :hash_secret => "longSecretString"

类别控制器

def index
  @categories = Category.all
end

def show
  @categories = Category.find_by_sql ["select distinct l.* from listings l , categories c, categories_listings cl where c.id = cl.category_id and l.id = cl.listing_id and c.id in (?,?)" ,  params[:c][:id1] , params[:c][:id2]]
end

sql 只是过滤并显示显示页面中的列表,我可以在其中显示其属性,但无法访问占位符。注意 show 中的复数 @categories

类别显示页面

<ul>
  <% @categories.each_with_index do |c, index| %>
  <% if  index == 0 %>
    <li class="first"><%= c.place %></li>

    <%= image_tag c.placeholder.url(:thumb) %>

    <li><%= c.price %></li>

    <% else %>
    <li><%= c.place %></li>
    <li><%= c.price %></li>

    <%= image_tag c.placeholder.url(:thumb) %>
    <% end %>

  <% end %>
</ul>

在轨道上使用回形针宝石红宝石的视图中从不同视图访问图像

这表示使对象复数并调用循环,wch 应允许访问图像。

在这种情况下它不起作用。

undefined method `placeholder' for #<Category:0x5c78640>

但令人惊奇的是,如果按照stackoverflow 中的建议使用,占位符将显示为所有列表的所有图像的数组,显然,wch 不是我喜欢的方式。问题出在哪里?我错过了什么?

4

1 回答 1

0

查看您的代码后,我可以看到的直接问题是模型placeholder的一部分listing.rb,而不是category.rb


活动记录对象

当您调用 ActiveRecord 对象(例如@categories = Category.all)时,ActiveRecord 对象会在Category模型上创建,这意味着必须像数组一样访问来自该对象的任何依赖项->@categories.listings

这些记录的关联是使用has_and_belongs_to_many您在模型中创建的各种关联创建的,这些关联似乎工作正常

所以我的建议是将列表称为 Category 的依赖项,如下所示:

<%= image_tag c.listings.first.placeholder.url(:thumb) %>

更新

要显示列表的所有图像,您只需执行一个.each循环,如下所示:

<ul>
  <% @categories.each_with_index do |c, index| %>
  <% if  index == 0 %>
        <li class="first"><%= c.place %></li>

        <% c.listings.each do |listing| %>
            <%= image_tag listing.placeholder.url(:thumb) %> 
        <% end %>

        <li><%= c.price %></li>
    <% else %>
        <li><%= c.place %></li>
        <li><%= c.price %></li>

        <% c.listings.each do |listing| %>
            <%= image_tag listing.placeholder.url(:thumb) %> 
        <% end %>

    <% end %>

  <% end %>
</ul>

ActiveRecord 和回形针

我认为结论是这样的:

您的 SQL 查询正在从您的列表数据库中带回“纯数据”。没关系,但是您想使用 Paperclip 的.url功能,该功能仅触发ActiveRecord(它创建一个图像对象并附加到 ActiveRecord 对象)

您的列表数据库具有以下列:

  • placeholder_file_name
  • placeholder_content_type
  • placeholder_file_size
  • placeholder_updated_at

这些无法为您创建图像输出,因为图像文件存储在不同的路径中placeholder_file_name

当您使用 Paperclip 时,它会获取存储在这些列中的数据并创建一个 ActiveRecord 图像对象,然后您可以使用c.listings.first.placeholder.url. 注意该placeholder列根本不在数据库中;ActiveRecord意思是在您可以使用它的功能之前,需要先调用回形针

可以使用这样的查询(老实说,这完全是在黑暗中刺探,但希望它能给您更多的洞察力):

@categories = Category.joins(:listings).where(:id => [params[:c][:id1],params[:c][:id2]])
于 2013-11-03T15:14:33.027 回答