[英]How to export a global scss variables file to be imported to all scss files in Rails 6 webpacker
[英]How can i make foundation global variables available to all my scss files in a rails app
我想知道如何在我的所有scss中使用颜色变量(例如$ light-gray)(我使用的是Foundation 6)。
我以为在我的应用程序顶部使用*= require foundation_and_overrides
requirefoundation_and_overrides。scss将使所有scss文件中的所有变量都可用,但出现以下错误Undefined variable: "$light-gray".
谢谢你的帮助。
我不知道这是否是最佳做法。 但是我这样做的方式是,我有另一个名为shared_variables.scss
scss文件。
// shared_variables.scss
$light-gray: #ccc;
然后在foundation_and_overrides.scss
内部,导入它(如果您要在此文件中使用变量):
// foundation_and_overrides.scss
// ...
@import 'foundation-functions';
@import 'shared_variables'; // Add this line
// ...
然后将其导入到其他依赖于全局变量的其他.scss
文件中;
// posts.scss
@import 'shared_variables'; // Add this line
.posts-container {
background: $light-gray;
}
基本上,我们不能使用@import全局创建变量。 这是原因:
Sass / Sass将获取您要导入的文件,并将其与要导入的文件合并,以便您可以将单个CSS文件提供给Web浏览器。
检查此以获取更多详细信息
假设您有几个Scss文件_reset.scss
和base.scss
。 我们想将_reset.scss
导入base.scss
。
_reset.scss
html,
body,
ul,
ol {
margin: 0;
padding: 0;
}
base.scss
@import 'reset';
body {
font: 100% Helvetica, sans-serif;
background-color: #efefef;
}
该base.scss
将产生base.css
是这样的:
base.css
html, body, ul, ol {
margin: 0;
padding: 0;
}
body {
font: 100% Helvetica, sans-serif;
background-color: #efefef;
}
因此import
工作就像将reset
内容替换为base
输入reset
的位置!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.