你的问题还是有点不清楚,也不清楚你已经尝试了什么(你甚至不包括完整的文件上方将更加清晰枚举当前使用的插件)以及原因。你问关于gulp-concat
的问题,但是代码中没有任何东西引用该模块。如果我理解你的问题,然后有一些我所知道的两个选项:
选项1:
var gulp = require('gulp');
var cleanCSS = require('gulp-clean-css');
var concat = require('gulp-concat');
gulp.task('minify-css', ['minify-first', 'minify-second', 'minify-third']);
gulp.task('minify-first', function() {
return gulp.src(['./assets/css/main.css', './assets/css/first.css'])
.pipe(cleanCSS())
.pipe(concat('first.min.css'))
.pipe(gulp.dest('./build/css/'));
});
gulp.task('minify-second', function() {
return gulp.src(['./assets/css/main.css', './assets/css/second.css'])
.pipe(cleanCSS())
.pipe(concat('second.min.css'))
.pipe(gulp.dest('./build/css/'));
});
gulp.task('minify-third', function() {
return gulp.src(['./assets/css/main.css', './assets/css/third.css'])
.pipe(cleanCSS())
.pipe(concat('third.min.css'))
.pipe(gulp.dest('./build/css/'));
});
选项2:
gulp.task('minify-css', ['minify-first', 'minify-second', 'minify-third']);
gulp.task('minify-first', minifyCss('first'));
gulp.task('minify-second', minifyCss('second'));
gulp.task('minify-third', minifyCss('third'));
function minifyCss(srcFileName) {
return function() {
return gulp.src(['./assets/css/main.css', `./assets/css/${srcFileName}.css`])
.pipe(cleanCSS())
.pipe(concat(`${srcFileName}.min.css`))
.pipe(gulp.dest('./build/css/'));
};
}
的rev
插件,你是利用上面的是将哈希键添加到目标css文件的那个。这是通常被认为是好事的缓存破坏措施。您可能会以不同的方式处理静态文件缓存,但可能不需要它。如果您确实想继续使用它,那么您可以添加一些构建步骤来更新包含这些引用的文件,以便每次更改其中一个文件时手动不必手动更新这些文件中的文件名css文件并运行一个新的版本。
这是很不清楚你想问什么。 '['assets/css/*。css']'应该选择该目录中的所有css文件并对它们进行操作。你最终想要两个css文件还是只有一个?你不喜欢文件名中的散列吗?如果是这样,这是由rev插件完成的,所以你应该删除与之相关的行。还是你问完全不同的东西? – peinearydevelopment
我想结合main.css和first.css。并结合main.css和last.css。并结合main.css和middle.css。所以我总共有3个缩小的css文件。 first.min.css,last.min.css和middle.min.css。所以我不必使用''link rel =“stylesheet”href =“build/css/main-08c0322a8a.css”type =“text/css”/> – moe