有config.assets.compile=true参数,它支持所谓的“实时编译”。我需要Rails在活模式下在每个请求上编译一个特定的资产(sample.css.scss.erb),但是其余的资产仍然应该被预编译。我怎样才能做到这一点?
发布于 2013-02-21 18:49:06
选项1-将sample.css.scss.erb放在与config.assets.manifest (default="public/assets")不同的路径中,并将其添加到javascript_include_tag中
选项2-将其从config.assets.precompile中删除
config.assets.precompile -= %w( sample.css.scss.erb )确保您清理,然后预编译来测试它。
我没有测试任何一个选项,请让我们知道是否对您有用。
发布于 2017-02-25 12:50:23
当.css.erb文件对css进行预处理时,需要对文件进行实时编译。它意味着动态编译css。
例如:允许用户设置颜色,并希望有条件地使用“实时编译”。
在这种情况下,我将建议动态地呈现/user/:id.css.erb,而不是实时编译。
原因可能有数百万用户,在生产环境中使用Ec2实例将花费您更多的时间。这就是为什么我会建议下面的解决方案:
首先在UsersController上定义自定义操作
# config/routes.rb
match '/users/:id/styles' => 'users#styles', :as => :user_styles链接到布局中的“样式表”:
# app/views/layouts/application.html.erb
= stylesheet_link_tag 'application', user_styles_path(current_user, :format => 'css')在控制器中定义操作。您可以在这里做任何想要检索用户首选项的操作:
# app/controllers/users_controller.rb
class UsersController < ApplicationController
def styles
@colors = User.find(params[:id]).colors
end
end该操作将自动呈现此视图:
# app/views/users/styles.css.scss.erb
$background-color: <%= @colors[:background] %>;
body {
background-color: $background-color;
}更多的想法和建议是最受欢迎的。
https://stackoverflow.com/questions/15009799
复制相似问题