加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 在Rails中,如何将资产管道中的样式表作为标记

发布时间:2020-12-16 21:00:07 所属栏目:百科 来源:网络整理
导读:每个人都知道如何使用stylesheet_link_tag链接到样式表,但我想在页面本身中实际包含整个样式表. (不,这通常不是一个很好的做法,但在这种情况下它是有道理的.) stylesheet_include_tag不存在,并且在Rails中比一个更大的坏人的同事比我说的没有一个简单的方法.
每个人都知道如何使用stylesheet_link_tag链接到样式表,但我想在页面本身中实际包含整个样式表. (不,这通常不是一个很好的做法,但在这种情况下它是有道理的.)

stylesheet_include_tag不存在,并且在Rails中比一个更大的坏人的同事比我说的没有一个简单的方法.

题:
实际上是否可以使用资产管道并仍然将CSS或JavaScript文件(从Sass或CoffeeScript编译!)的内容嵌入到.haml视图中?怎么样?

为清晰起见添加:

我希望我的布局能够包含以下内容:

= stylesheet_link_tag "base"
= stylesheet_embed_tag "page-specific-styles/foo"

并按照这些行生成输出HTML:

<link rel="stylesheet" href="/base.css" />
<style type="text/css">.foo { color: red; }</style>

更新

如果你是set your initalizer correctly,可以在Haml中使用Sass,但我似乎不能从这个上下文中@import“foo”,其中foo.css.sass是资产管道中的样式表.请注意,@ import“指南针”(假设您有指南针宝石)确实有效.

这看起来像(haml):

%style
  :sass
    @import "foo"

Rails给出了一个错误,即“foo”无法找到,即使它声称要查看app / assets / stylesheets(foo.css.sass所在的位置).

所以,这感觉更接近,但仍然不完全.

解决方法

从 http://blog.phusion.nl/2011/08/14/rendering-rails-3-1-assets-to-string/:

YourApp :: Application.assets.find_asset( ‘api.css’).源

在haml

%style
    =raw YourApp::Application.assets.find_asset('foo.css').source

注意事项:

我认为这需要在生产中进行资产编译,这可能非常昂贵.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读