【问题标题】:rails content_for not workingrails content_for 不工作
【发布时间】:2014-01-30 01:47:43
【问题描述】:

我想让我的 javascript/coffescript 文件只加载到使用它们的页面上。所以在我的 application.html.erb 文件中,我脑子里有以下代码

<%= yield :head %>

然后在我想要加载我拥有的javascript的特定视图中

<% content_for(:head) do%>
<%= javascript_include_tag 'application' %>
<% end%>

这似乎最初有效。当我第一次访问我不想要 javascript 的页面时,没有指向 js 文件的链接。但是,一旦我访问了具有上述代码块的页面,链接就会显示在我访问的所有后续页面中(例如主页)。如果我然后刷新主页中的浏览器,链接会再次消失......

这本身并不是一个真正的问题,但我的 application.html.erb 头部也有这个

<style><%= yield :stylesheets %></style>

并且在某些布局中,有 css 可以让步。这就是它变得非常奇怪的地方。假设页面 A 没有 js 也没有额外的 css,页面 B 没有 js 但有额外的 css,页面 C 有 js 和额外的 css。然后我按顺序执行以下操作:

Visit page A => everything is fine
Visit page B => everything is fine (additional css is loaded)
visit page A again => everything is fine (additional css is not loaded)
visit page C => everything is fine (additional css and js loaded)
visit page A again => NOT GOOD!!! (additional css and js still loaded)

不知何故,javascript include 标记也导致我的 content_for(:stylesheets) 内容持续存在,即使我不希望它存在。如果我在页面 A 上进行手动刷新,一切都会再次恢复正常,直到我访问页面 C。我什至尝试将它放在我的页面 A 视图中以摆脱链接,但仍然没有好处

<% content_for(:head) do%>
<% end%>

有什么想法吗?

【问题讨论】:

  • 您是否启用了 Turbolinks?
  • 是的,我认为默认情况下是对的?

标签: layout ruby-on-rails-4 yield content-for


【解决方案1】:

启用 turbolinks 后,它将无法工作。您需要做的是禁用 turbolinks 或将您的 javascript 和 css 放在页面正文中。

【讨论】:

  • 在禁用 turbolinks 的情况下,它仍然对我不起作用。
【解决方案2】:

更新您的config/initializers/assets.rb

在里面添加您的filename.js 文件或**/*.js Rails.application.config.assets.precompile += %w( filename.js)

运行RAILS_ENV=production rake assets:precompile 取决于您的环境。如果您在本地工作,请跳过该命令,因为它会根据您的配置动态预编译。

重新启动您的应用,应该可以在关闭 turbolinks 并从头部或身体中屈服的情况下工作。

【讨论】:

    【解决方案3】:

    我用过

    <% content_for :head do %>
    <% end %>
    

    但没有在我的相关布局的 head 标签中使用 ,这对我来说是个问题。

    更多这些是平等的

    <%= content_for :head %>
    or
    <%= yield :head %>
    

    【讨论】:

      猜你喜欢
      • 2020-03-03
      • 2021-06-06
      • 2011-05-19
      • 2017-06-01
      • 2022-08-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多