Gulp正在修改我的font-face url路径

时间:2015-06-27 23:23:06

标签: javascript node.js gulp

编辑: 如果我在任务中只有一个文件,gulp-flatten,问题就会消失。也就是说,如果我的gulp.src只调用一个文件,那么gulp-flatten实际上会删除修改后的路径。我需要能够合并我的供应商css。

gulp.task('libCSS2', function() {
    gulp.src(vendor + '/font-awesome/css/font-awesome.min.css')
        .pipe(flatten())
        .pipe(concatCss('vendor.css'))
        .pipe(gulp.dest(dest + '/css'));
});

在构建时,Gulp正在改变这一点(来自CSS源文件):

src: url('../fonts/fontawesome-webfont.eot?#iefix&v=4.3.0')

到此(CSS构建文件)

 src: url("../../../font-awesome/fonts/fontawesome-webfont.eot?#iefix&v=4.3.0")

基本上它增加了一条相对于旧的fontawesome位置的新路径,我想摆脱它。它为每个网址执行此操作:因此引导网址也会混乱。我相信这是一个默认的gulpfonctionnality。 这是我的任务,你可以看到我尝试了gulp-flatten插件但没有成功

/* ===== CSS LIB START ===== */
gulp.task('libCSS', function() {
    // Define libraries locations
    var bootstrapCss = vendor + '/bootstrap/dist/css/bootstrap.min.css';
    var slickCss = vendor + '/slick.js/slick/slick.css';
    var slickCss2 = vendor + '/slick.js/slick/slick-theme.css';
    var materializeCss = vendor + '/materialize/dist/css/materialize.min.css';
    var fontawesomeCSS = vendor + '/font-awesome/css/font-awesome.min.css';

    // Merge libraries
    return gulp.src([bootstrapCss, slickCss, slickCss2, materializeCss, fontawesomeCSS])
        // Concatenate in a single file
        .pipe(concatCss('vendor.css'))
        .pipe(flatten(''))
        .pipe(gulp.dest(dest + '/css'));
});

这是我的文件夹组织

app/
----vendor/
--------boostrap/
--------slick.js/
--------materialize/
--------font-awesome/
------------css/
----------------font-awesome.min.css // font-awesome goes from there
build/
----css/
--------vendor.css // to there

由于

1 个答案:

答案 0 :(得分:5)

concateCss是罪魁祸首

.pipe(concatCss('vendor.css', {rebaseUrls:false}))

解决了问题