Sinatra SASS自定义目录

时间:2012-09-04 17:15:38

标签: ruby sinatra

如何配置Sinatra使用自定义SCSS目录? 我尝试了以下解决方案,但这对我不起作用。

class SassEngine < Sinatra::Base

set :views, File.dirname(__FILE__) + '/sass'

get '/sass/*.scss' do
    filename = params[:splat].first
    sass filename.to_sym
end

end

2 个答案:

答案 0 :(得分:4)

实际上,官方文档中有一个完全针对此用例的部分。

为了使这里更容易,代码(取自文档):

set :views, :sass => 'views/sass', :haml => 'templates', :default => 'views'

helpers do
  def find_template(views, name, engine, &block)
    _, folder = views.detect { |k,v| engine == Tilt[k] }
    folder ||= views[:default]
    super(folder, name, engine, &block)
  end
end

完成此配置后,您只需执行以下操作:

get '/css/a_css_file.css' do
  sass :a_css_file
end

或更通用的方法:

get '/css/*.css' do
  file = params[:splat].first
  sass file.to_sym
end

虽然最后一个不是一个好的方法,但是如果它会导致错误 调用不存在的文件。

答案 1 :(得分:0)

我找到了解决方案。

require 'sinatra'
require 'dm-core'
require 'dm-migrations'
require 'haml'
require 'sass'
require 'shotgun'


set :views, :scss => 'views/', :haml => 'template', :default => 'views'

 helpers do
   def find_template(views, name, engine, &block)
     _, folder = views.detect { |k,v| engine == Tilt[k] }
     folder ||= views[:default]
     super(folder, name, engine, &block)
   end
 end


get '/css/:name.css' do
  scss :styles
end


get '/' do
  haml :index
end

你可以看到,而不是:

get '/css/styles.css' do
  sass :styles
end

应该是:

get '/css/:name.css' do
  scss :styles
end

然后我将styles.scss放入my / views文件夹。但是,您可以通过编辑:scss =&gt;来修改目标目录。 &#39; .scss文件的路径:

set :views, :scss => 'views/', :haml => 'template', :default => 'views'