我目前正在使用 sinatra 制作一个应用程序,并且我已经工作了几个小时来尝试在其中实现引导程序,并意识到它在 Rails 中是多么容易。
无论如何,当我运行 Web 服务器并转到 / 时,我看到与<%= stylesheet_link_tag 'app', media: 'all' %>
我放入 app.erb 视图(我的 webapp 的索引)中的行有关的错误。此行用于在 assets/stylesheets 文件夹中加载一个 scss 文件,该文件包含引导程序的 @import 值。
我正在使用 sinatra-asset-pipeline gem,并根据 github 页面上的说明正确设置了它。在过去的 4 个小时里,我一直在尝试很多东西,但没有任何效果。这是最重要文件的代码:
资产/样式表/app.scss:
@import "bootstrap-sprockets";
@import "bootstrap";
意见/app.erb:
<!DOCTYPE html>
<html>
<head>
<title>Salah Kayali</title>
<%= stylesheet_link_tag 'app', media: 'all' %>
<%= javascript_include_tag 'app' %>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<%= partial :header %>
</body>
</html>
应用程序.rb:
require 'sinatra/partial'
require 'rubygems'
require 'sinatra'
# set :bind, '0.0.0.0'
require 'sinatra/asset_pipeline'
class App < Sinatra::Base
register Sinatra::Partial
configure do
set :assets_precompile, %w(app.js app.scss *.png *.jpg *.svg *.eot *.ttf *.woff)
set :assets_css_compressor, :sass
set :assets_js_compressor, :uglifier
register Sinatra::AssetPipeline
if defined?(RailsAssets)
RailsAssets.load_paths.each do |path|
settings.sprockets.append_path(path)
end
end
end
enable :partial_underscores
set :partial_template_engine, :erb
get '/' do
erb :app
end
run! if __FILE__ == $0
end
配置.ru:
require 'rubygems'
require 'bundler'
Bundler.require
run App
耙文件:
require 'sinatra/asset_pipeline/task'
require './app'
Sinatra::AssetPipeline::Task.define! App
宝石文件:
source "https://rubygems.org"
ruby "2.2.3"
gem 'bundler', '~> 1.10.6'
gem 'sinatra', require: 'sinatra/base'
gem 'sinatra-asset-pipeline', require: 'sinatra/asset_pipeline'
gem 'thin', '~> 1.6.4'
gem 'sass', '~> 3.4.18'
gem 'coffee-script', '~> 2.4.1'
gem 'uglifier', '~> 2.7.2'
gem 'rack-coffee', '~> 1.0.3'
gem 'sinatra-partial'
source 'https://rails-assets.org' do
gem 'rails-assets-jquery'
gem 'rails-assets-bootstrap-sass'
end
我希望有人可以提供帮助,因为我真的不知道该怎么做。我通常习惯于 rails,asset-pipeline 已经存在并且可以处理所有事情。不过,我强迫自己用 sinatra 制作这个 webapp,这样我才能真正理解当你“自动”用 rails 创建东西时实际发生了什么。
这是我浏览器中错误输出屏幕截图的链接:http: //puu.sh/ktUIA/1d8396b034.png