我的index.html.erb
代码-
<h1>Listing products</h1>
<table border="1">
<% @products.each do |product| %>
<tr>
<td><%= product.title %></td>
<td><%= product.description %></td>
<td><%= image_tag(product.image_url, :class => 'list_image') %></td>
<td><%= product.price %></td>
<td><%= link_to 'Show', product %></td>
<td><%= link_to 'Edit', edit_product_path(product) %></td>
<td><%= link_to 'Destroy', product, method: :delete, data: { confirm: 'Are you sure?' } %></td>
</tr>
<% end %>
</table>
<br />
<%= link_to 'New Product', new_product_path %>
图像低于app\assets\images
..但前端不显示静止图像。
当我Firebug
它,我相信图像标签是正确的形成...让我知道我在这一部分错过了什么。
<img src="/images/product1.jpg" class="list_image" alt="Product1">
屏幕截图-
图像也已准备就绪-
让我知道我做错了什么,我该如何解决它。
编辑
github.com/swapnesh/depot
让我知道为什么它在我的情况下不起作用。
尽管将/images/product1.jpg
更改为/assets/product1.jpg
可以使其正常工作。
5条答案
按热度按时间vulvrdjw1#
如果您收到一个扩展名为.jpeg的文件,请尝试用.jpg重命名该文件。
起始日期
收件人:
uelo1irk2#
如果您正在阅读《Agile Web Development With Rails》一书,那么html.erb代码就没有问题。唯一的问题是scss文件。请检查您是否将td.image display设置为none!将display更改为block,您将看到图像。
e0uiprwp3#
如果您正在使用资产管道http://guides.rubyonrails.org/asset_pipeline.html,
图像路径应为
/assets/product1.jpg
,而不是/images/product1.jpg
如果未使用资产管道,请将images文件夹移动到
public/images
vzgqcmou4#
我刚刚检查了你的应用程序,你的代码没有问题。唯一的问题是了解image_tag是如何工作的。
通常你把所有的图像、javscript和样式表放在app/assets目录中。当你在开发环境中工作时,这些文件是以未压缩的形式提供的,但是当你部署到生产环境中时,资产被预编译、缩小,结果文件存储在public/assets中。
缩小资产背后的想法,只是为了使客户端的请求更快,并保存带宽。
现在,在方法image_tag上,可以使用图像的外部路径、图像的本地路径或图像的相对路径。
当你这样做
它将使用图像标记的绝对url,并以
您也可以添加本地路径,如
这将在
这实际上就是您遇到的问题,因为Rails在预编译文件时,会将所有内容放在**/public/assets中,您可以通过转到路径/assets**来访问这些文件,正如其他用户所解释的那样。
所以代码
实际上是有效的,因为你以
你可以做的另一件事是使用相对路径,即
将转换为
这与上一个场景的工作原理相同。
然而,在您的应用程序中,您将允许用户上传自己的图像,这将在您以后的书中进行,在真实的应用程序中,您将使用paperclip或carrierwave等gem
xfb7svmp5#
正如Srikanth已经说过的,assets路径应该被引用,作为一个例子,你可以把
<%= image_tag 'rails.png' %>
放在你的代码中,然后检查firebug(或者chrome中的inspect元素)来检查结果。我不太确定为什么您的代码不能工作,因为我可以看到您使用了Rails进行Agile Web Development。我可以正常运行仓库应用程序。在您的表格中,我看到了“Product1”、“Product2”和“Product3”,这是您在image_url text_field中实际填写的内容吗?如果您将“Product1”更改为“product1.jpg”,会发生什么情况?
顺便说一句,如果你想使用曲别针,你的电话应该看起来像这样: