微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

使用Ruby的Compass(不是shell)

我正在Ruby中构建一个脚本,我想用Compass编译一个SCSS文件.我试图尽可能简单,并希望避免使用config.rb文件.我只想通过直接Ruby设置一些设置,并告诉Compass将单个SCSS文件编译成CSS文件.

我知道这必须是可能的,但我还没有找到关于如何做到这一点的任何体面的文件.任何帮助,将不胜感激.

解决方法

你是对的,关于如何使用Ruby的Compass,还没有任何全面的文档.这很不幸,但是不要让像文档这样的小细节阻止我们!

第一次尝试

当我想要做同样的事情时,我只是在Compass source周围探索并且能够整合这个小Ruby脚本.乍一看似乎可以解决这个问题:

require 'compass'
require 'sass/plugin'

compiler = Compass::Compiler.new(
    # Compass working directory
    '.',# Input directory
    'styles/scss',# Output directory
    'styles/css',# Compass options
    { :style => :compressed }
)

compiler.compile('test.scss','test.css')

但显然Compass有一堆认配置选项,在直接调用编译器构造函数时(SASS load_path为1)不会自动包含这些选项.尝试导入Compass函数和mixins时,这可能会导致错误,例如:

error: File to import not found or unreadable: compass/css3

指南针< 1.0.0(a.k.a.“老路”) 以下是如何在不覆盖这些认值的情况下调用编译器:

require 'compass'

Compass.add_configuration(
    {
        :project_path => '.',:sass_path => 'styles/scss',:css_path => 'styles/css'
    },'custom' # A name for the configuration,can be anything you want
)
Compass.compiler.compile('test.scss','test.css')

但是,从Compass版本1.0.0开始,Compass.compiler已被弃用,转而使用Compass.sass_compiler,导致……

指南针> = 1.0.0(a.k.a.“新方式”)

感谢@philipp查找how to use the new API,我们可以再次更新此片段以使用Compass.sass_compiler:

require 'compass'
require 'compass/sass_compiler'

Compass.add_configuration(
    {
        :project_path => '.',can be anything you want
)

compiler = Compass.sass_compiler({
  :only_sass_files => [
    'styles/scss/test.scss'
  ]
})

compiler.compile!

原文地址:https://www.jb51.cc/ruby/274423.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐