覆盖 Spree Commerce 的 Bootstrap 变量

Override Spree Commerce's Bootstrap Variables

我在将自定义 _variables.scss 作为编译资产部署到我的生产服务器时遇到问题。

我的开发环境一切正常,但在生产环境中我的变量被覆盖了。

我正在使用 Rails 4.2.1 和 Spree 3.0 稳定分支。

我有以下结构:

vendor/assets/stylesheets/frontend

中创建的文件

_variables.scss 包含以下内容:

// Place all Sass variables here.

// Colors
$brand-primary: green;
$gray: #aaa;

// Navbar
$navbar-default-bg: #fff;
$navbar-height: 100px;
$navbar-border-radius: 0;
$navbar-default-border: none;
$navbar-default-toggle-hover-bg: $navbar-default-bg;
$navbar-default-toggle-icon-bar-bg: lighten($gray, 60%);
$navbar-default-toggle-border-color: $navbar-default-bg;
$navbar-default-link-active-bg: $brand-primary;

frontend_boostrap.css.scss 包含以下内容:

// Spree Bootstrap Override

// Core
@import "variables";
@import "bootstrap-sprockets";
@import "bootstrap";

// Custom Overrides
@import "navbar";

navbar.scss 包含以下内容:

// Navbar Customization

.navbar-myapp {
  margin-bottom: 40px;
  border-top: none;
  border-bottom: 1px solid $navbar-default-toggle-icon-bar-bg;

  .navbar-brand {
    padding: 15px;
  }
}

Rails 标准 app/assets/stylesheets/application.css 清单没有 used/I 没有在其中声明任何特定内容。

生成的HTML头部代码显示all.css和前端。

<link rel="stylesheet" media="screen" href="/assets/spree/frontend/all.self-33fc4a513acb9a5f3fd4ba26b89c94184e5d028c4bd40eee6736d3ccfea5c140.css?body=1">

<link rel="stylesheet" media="screen" href="/assets/spree/frontend/frontend_bootstrap.self-88eb7ced3e4d78d298a33264c3cfc65af6cef8ac32ae56a7dd7a3e321ba97378.css?body=1">

一切都在开发中,但是当我将它部署到我的测试服务器时,一些变量被默认覆盖,这包括导航栏配置和颜色。

我不确定这是不是因为资产编译顺序;或者如果它是 bootstrap-sass 的导入方式。

关于如何在不被覆盖的情况下使用 _variables.scss 有什么建议吗?我不想要任何重复,这就是为什么我想更改变量 sass 文件中的导航栏和颜色。

看来我已经解决了这个问题。

Bootstrap Sass gem 状态:

Do not use //= require in Sass or your other stylesheets will not be able to access the Bootstrap mixins or variables.

为了让它在生产/编译资产中工作。我必须:

  1. 将all.css更改为all.scss
  2. 将 //= require 语句更改为 @import

vendor/assets/stylesheets/spree/frontend/all.scss:

// Sass Application Manifest

@import "frontend_bootstrap";

vendor/assets/stylesheets/spree/frontend/frontend_bootstrap.css.scss:

// Spree Bootstrap Override

// Core
@import "bootstrap-sprockets";
@import "variables";
@import "bootstrap";

我希望这对像我一样跌跌撞撞的人有所帮助。