- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试在我的项目中开始使用 Bourbon 和 Neat Sass 库。我想用 Gulp 编译 Sass。这是我在其中一个教程中找到的一个简单的 styles
任务设置:
var gulp = require('gulp'),
sass = require('gulp-sass'),
neat = require('node-neat').includePaths;
var paths = {
scss: './assets/styles/*.scss'
};
gulp.task('styles', function () {
return gulp.src(paths.scss)
.pipe(sass({
includePaths: ['styles'].concat(neat)
}))
.pipe(gulp.dest('./dist/styles'));
});
gulp.task('default', function () {
gulp.start('styles');
});
然后在主 .scss
文件中我放置导入:
@import "bourbon";
@import "base/base";
@import "neat";
该任务正确执行。
让我困惑的是 includePaths
到底做了什么?根据上面的例子,有人可以向我解释一下 includePath
的作用是什么吗?
最佳答案
SASS 编译器在解析 SASS @imports 时使用 loadPaths 中的每个路径。
loadPaths: ['styles/foo', 'styles/bar']
@import "x"; // found via ./styles/foo/_x.scss
@import "y"; // found via ./styles/bar/_y.scss
请注意,编译器通过从从左到右考虑loadPaths
中的每个路径来解析每个@import(类似于UNIX环境中的$PATH
)。一个示例场景可能是:
loadPaths: ['styles/i', 'styles/ii', 'styles/iii', 'styles/iv']
@import "x"; // no file at ./styles/i/_x.scss
// no file at ./styles/ii/_x.scss
// found a file at ./styles/iii/_x.scss ...
// ... this file will be used as the import
// ... terminate lookup
// the file ./styles/iv/_x.scss will be ignored
styles/i
中没有 _x.scss
文件,因此它继续查看 styles/ii
内部。最终它在styles/iii
中找到了一个_x.scss
文件并完成了查找。它从数组中的第一个元素开始向右移动,查看 loadPaths 中的每个文件夹。尝试所有路径后,如果找不到该文件,则声明此 @import 语句无效。
如果您有外部库(例如 bournon/neat),加载路径会很有用。外部库很大并且会使用大量@import语句。但是,它们与您的项目文件夹结构不匹配,因此无法解析。但是,您可以向 loadPaths 添加额外的文件夹,以便外部库内的 @importsdo 得到解析。
关于sass - Gulp 的 includePaths 有什么作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35379396/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!