1

我在使用我的 haml 模板进行 sass 工作时遇到问题。

最近我的主要 sinatra.rb 应用程序中有以下代码:

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


set :views, :sass => 'views/css', :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/styles.css' do
sass :styles
end


get '/' do
haml :index
end


I have following application directory structure:
site
|site.rb
|-sass > styles.scss (my scss file generate css realtime using sass --watch sass:css command                                   
|-css > styles.css 
|-template > index.haml

我在模板文件夹中的 index.haml 文件渲染得很好。

我的 index.haml 模板:

!!! XML
!!!
%html
%head
    %title Some title
    %meta{"http-equiv" => "Content-Type", :content => "text/html; charset=utf-8"}
    %link{"rel" => "stylesheet", "href" => "views/css/styles.css", "type" => "text/css"}
%body
    %h1 Some h1 
    %p Some p
4

3 回答 3

2

您需要将 sass 视图目录设置为正确的目录。

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

如果你想让 sass 返回渲染后的 styles.css,那么它需要从 sass 文件所在的位置开始。如果您希望它返回实际的 .css 输出,则不要在您的路由中渲染它,只需返回文件即可。

于 2012-09-05T17:45:12.807 回答
2

您已经给出了视图文件的路径,而不是渲染 SASS 文件的路径的路径。

%link{"rel" => "stylesheet", "href" => "/css/styles.css", "type" => "text/css"}
于 2012-09-05T17:47:43.873 回答
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 放到我的/views 文件夹中。但是,您可以通过编辑 :scss => ' .scss 文件的路径来修改目标目录:

set :views, :scss => 'views/', :haml => 'template', :default => 'views'
于 2012-09-06T05:12:12.507 回答