在 rails6 开发中禁止加载所有样式表

Disable loading all stylesheets in rails6 development

我想 load/unload the specific css debugging bulma structures 通过 comment/uncomment stylesheet_link_tag 的行:

# app/view/layouts/application.html.erb
...
    <%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>

    <%# Bulma %>
    <%= stylesheet_link_tag 'https://cdn.jsdelivr.net/npm/bulma@0.9.1/css/bulma.min.css', media: 'all' %>
    <%# Debugger on/off by comment/uncomment %>
    <%# <%= stylesheet_link_tag 'bulma/debug' %> <- this line!
    <%= javascript_pack_tag 'application', 'data-turbolinks-track': 'reload' %>
...

我的样式表目录树是这样的:

app/assets/stylesheets/
├── application.css
├── bulma
│   ├── debug.css
│   └── grid.css
└── posts.scss

但是当我像上面那样评论那一行时,css 文件被加载(并且 grid.css)。

我认为link_directory只是样式表目录,不能递归加载:

# app/assets/config/manifest.js
//= link_tree ../images
//= link_directory ../stylesheets .css

所有其他配置默认为 Rails 6.1.3.

为什么 app/assets/stylesheets/bulma/debug.css 会自动加载,我该如何禁用它?

在您的 application.css 文件中,您可能有这样一行 *= require_tree . 这将自动包含您的 app/assets/stylesheets 目录中的所有内容。

尝试在该行之后的下方添加类似 *= stub 'bulma/debug' 的内容。这应该会阻止文件加载。

它目前不在 rails 官方 rails 文档中(据我所知),但您可以找到 stub 和相关的 Sprockets 方法 on Github