gpt4 book ai didi

sass - Gulp 的 includePaths 有什么作用?

转载 作者:行者123 更新时间:2023-12-03 11:23:59 25 4
gpt4 key购买 nike

我正在尝试在我的项目中开始使用 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

没有 _x.scss文件在 styles/i ,所以它继续往里面看 styles/ii .最终它找到了一个 _x.scss文件在 styles/iii并完成了查找。它查看 loadPaths 中的每个文件夹从数组中的第一个元素开始向右移动。尝试所有路径后,如果找不到文件,则声明此@import 语句无效。

如果您有外部库(如 bournon/neat),则加载路径很有用。
外部库很大,将使用大量@import 语句。但是,它们与您的项目文件夹结构不匹配,因此无法解析。但是,您可以向 loadPaths 添加额外的文件夹,以便外部库中的 @imports 解析。

关于sass - Gulp 的 includePaths 有什么作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33585617/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com