用gulp-rev修改gulp,gulp-rev-replace,gulp-rev-css-url

时间:2015-12-16 09:27:30

标签: css gulp versioning gulp-rev

我正在尝试使用gulp-rev,gulp-rev-replace和gulp-rev-css-url重新编写对我的版本化图像文件的引用。

我已设法修改文件并将清单与以下gulp代码合并:

gulp.task('revision', function(callback){
    runSequence('revision-images', 'revision-scripts', 'revision-css', 'revreplace',  callback);
});

gulp.task('revision-scripts', function(){
    return gulp
        .src('./build/*.js')
        .pipe(rev())
        .pipe(gulp.dest('./dist/build'))
        .pipe(rev.manifest({
            base: process.cwd(),
            merge: true
        }))
        .pipe(gulp.dest('./dist'));
});

gulp.task('revision-css', function(){
    return gulp
        .src('./build/*.css')
        .pipe(rev())
        .pipe(override())
        .pipe(gulp.dest('./dist/build'))
        .pipe(rev.manifest({
            base: process.cwd(),
            merge: true
        }))
        .pipe(gulp.dest('./dist'));
});

gulp.task('revision-images', function(){
    return gulp
        .src(['./static-assets/img/*.*'])
        .pipe(rev())
        .pipe(gulp.dest('./dist/static-assets/img'))
        .pipe(rev.manifest({
            base: process.cwd(),
            merge: true
        }))
        .pipe(gulp.dest('./dist'));
});

gulp.task("revreplace", function(){

    var manifest = gulp.src('./dist/rev-manifest.json');

    return gulp.src('./index.html')
        .pipe(revReplace({
            manifest: manifest
        }))
        .pipe(gulp.dest('./dist'));
});

这会在正确的位置生成合并的清单文件,并且还会生成正确版本化的静态资产。

问题是它没有重新编写版本化CSS中版本化图像的引用。

运行'revision-css'时,我确实看到了对另一个CSS导入的更新引用,但图像引用仍然是未版本化文件的引用。

我使用run-sequence包来强制版本控制和清单合并,以便替换最后执行,但我不确定运行顺序是否是问题。

我的图像通常在CSS中引用:

background: url("../static-assets/img/nav-logo.png") no-repeat;

1 个答案:

答案 0 :(得分:4)

我使用了gulp-rev-all:

https://github.com/smysnk/gulp-rev-all

哪个有效:)