【问题标题】:rails paperclip unable to access image from another viewrails 回形针无法从另一个视图访问图像
【发布时间】:2013-11-04 01:24:04
【问题描述】:

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

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

listing.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>

Access image from different view in a view with paperclip gem ruby on rails

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

在这种情况下不起作用。

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

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

【问题讨论】:

  • 您在 category.rb 模型中是否设置了相关的has_and_belongs_to_many 关系?
  • 一切都是 der。我可以在类别显示页面中显示列表及其所有属性,但不能显示占位符图像。
  • 你在分类数据库中有占位符图像列吗?
  • 没有。我想如何设置它并将其链接到列表模型。此外,回形针根据占位符生成 4 列。它是如何工作的,只调用占位符。
  • 对不起,我想我把你弄糊涂了!我真正的意思是“您是否根据需要设置了回形针列,它们是否在标准情况下工作?”

标签: ruby-on-rails ruby ruby-on-rails-3 paperclip


【解决方案1】:

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


ActiveRecord 对象

当您调用 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]])

【讨论】:

  • 好的,它显示了占位符的第一个实例。因为,结果将显示许多列表,它不适用于其余列表。我使用 sql coz 用户可以根据他们的选择过滤列表。我相信,正如你所建议的,问题可能出在 sql 上。现在继续前进,我想如何让它发挥作用??
  • 好的,谢谢回复!我的修复只显示一张图片?这很好,因为这意味着我们走在正确的轨道上。这也意味着我们可能不必更改您的 SQL.... 让我进行编辑
  • 现在它显示了为每个列表存储的所有图像。好吧,我的意思是显示与列表的每个实例相关的占位符图像。例如,如果结果显示 2 列出了 a 和 b,则与“a”关联的图像及其其他属性,然后与“b”关联的图像及其其他属性。像这样。
  • === 查看您的代码后,我可以看到的直接问题是占位符是 listing.rb 模型的一部分,而不是 category.rb ==== 但我猜 sql 存储所有@category 对象中列表的属性,也就是说,我可以轻松地调用 c.price,c.place。但 y 不是占位符。
  • 因为占位符是Listing 模型的一部分,而不是Category 模型的一部分。 ActiveRecord 的工作方式是将其关联记录调用为类似数组的依赖对象,需要在输出任何引用的对象之前调用这些对象,例如 @categories.listings.placeholder.url
猜你喜欢
  • 1970-01-01
  • 2016-08-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-05-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多