簡體   English   中英

使用gulp-jade的yeoman Webapp生成器發生Gulp錯誤

[英]Gulp error with yeoman webapp generator using gulp-jade

我很難將玉與yeoman的gulp webapp生成器集成在一起。 watch任務已經按預期工作,但是一旦我嘗試構建項目,就會收到以下錯誤:

stream.js:94
      throw er; // Unhandled stream error in pipe.
            ^
TypeError: path must be a string

我認為這是因為我更改了html任務以return gulp.src('.tmp/*.html')最初是'app/*.html' ,它運行時沒有錯誤,但是當然忽略了我的Jade模板 ) 。

我的gulpfile:

'use strict';
// generated on 2014-04-17 using generator-gulp-webapp 0.0.7

var gulp = require('gulp'),
    jade = require('gulp-jade');

// load plugins
var $ = require('gulp-load-plugins')();

gulp.task('styles', function () {
    return gulp.src('app/styles/main.sass')
        .pipe($.rubySass({
            style: 'expanded',
            compass: true,
            loadPath: 'app/bower_components'
        }))
        .pipe($.autoprefixer('> 5%', 'last 3 versions', 'ff >= 20', 'ie 9'))
        .pipe(gulp.dest('.tmp/styles'))
        .pipe($.size());
});

gulp.task('templates', function() {
    var YOUR_LOCALS = {};

    return gulp.src('app/*.jade')
        .pipe(jade({
            locals: YOUR_LOCALS,
            pretty: true
        }))
        .pipe(gulp.dest('.tmp'))
        .pipe($.size());
});

gulp.task('scripts', function () {
    return gulp.src('app/scripts/**/*.js')
        .pipe($.jshint())
        .pipe($.jshint.reporter($.jshintStylish))
        .pipe($.size());
});

gulp.task('html', ['templates', 'styles', 'scripts'], function () {
    var jsFilter = $.filter('**/*.js');
    var cssFilter = $.filter('**/*.css');

    return gulp.src('.tmp/*.html')
        .pipe($.useref.assets())
        .pipe(jsFilter)
        .pipe($.uglify())
        .pipe(jsFilter.restore())
        .pipe(cssFilter)
        .pipe($.csso())
        .pipe(cssFilter.restore())
        .pipe($.useref.restore())
        .pipe($.useref())
        .pipe(gulp.dest('dist'))
        .pipe($.size());
});

gulp.task('images', function () {
    return gulp.src('app/images/**/*')
        .pipe($.cache($.imagemin({
            optimizationLevel: 3,
            progressive: true,
            interlaced: true
        })))
        .pipe(gulp.dest('dist/images'))
        .pipe($.size());
});

gulp.task('fonts', function () {
    return $.bowerFiles()
        .pipe($.filter('**/*.{eot,svg,ttf,woff}'))
        .pipe($.flatten())
        .pipe(gulp.dest('dist/styles/fonts'))
        .pipe($.size());
});

gulp.task('clean', function () {
    return gulp.src(['.tmp', 'dist'], { read: false }).pipe($.clean());
});

gulp.task('build', ['html', 'images', 'fonts']);

gulp.task('default', ['clean'], function () {
    gulp.start('build');
});

gulp.task('connect', function () {
    var connect = require('connect');
    var app = connect()
        .use(require('connect-livereload')({ port: 35729 }))
        .use(connect.static('app'))
        .use(connect.static('.tmp'))
        .use(connect.directory('app'));

    require('http').createServer(app)
        .listen(9000)
        .on('listening', function () {
            console.log('Started connect web server on http://localhost:9000');
        });
});

gulp.task('serve', ['connect', 'styles', 'templates'], function () {
    require('opn')('http://localhost:9000');
});

// inject bower components
gulp.task('wiredep', function () {
    var wiredep = require('wiredep').stream;

    gulp.src('app/styles/*.sass')
        .pipe(wiredep({
            directory: 'app/bower_components'
        }))
        .pipe(gulp.dest('app/styles'));

    gulp.src('app/*.html')
        .pipe(wiredep({
            directory: 'app/bower_components'
        }))
        .pipe(gulp.dest('app'));
});

gulp.task('watch', ['connect', 'serve'], function () {
    var server = $.livereload();

    // watch for changes

    gulp.watch([
        'app/*.html',
        'app/**/*.jade',
        '.tmp/styles/**/*.css',
        'app/scripts/**/*.js',
        'app/images/**/*'
    ]).on('change', function (file) {
        server.changed(file.path);
    });

    gulp.watch('app/**/*.jade', ['templates']);
    gulp.watch('app/styles/**/*.sass', ['styles']);
    gulp.watch('app/scripts/**/*.js', ['scripts']);
    gulp.watch('app/images/**/*', ['images']);
    gulp.watch('bower.json', ['wiredep']);
});

有什么建議么?

顯然,該錯誤來自gulp-useref對我的構建塊的問題。 更改所有塊以使用{app,.tmp}作為其搜索路徑可以解決此問題,例如:

// build:js({app,.tmp}) scripts/vendor/modernizr.js 
script(src='bower_components/modernizr/modernizr.js')
// endbuild

我遇到了同樣的問題。

要解決您的wiredep任務,請將其添加到gulp.src('app/*.html')塊之后:

gulp.src('app/*.jade')
    .pipe(wiredep({
        directory: 'app/bower_components'
    }))
    .pipe(gulp.dest('app'));

當您的bower.json觸發的bower.json更改時,這將更新.jade文件中的// bower:js ... // endbower塊:

gulp.watch('bower.json', ['wiredep']);

在您的gulpfile的末尾。

例如。

當我在我的bower.json添加"jquery": "~1.11.0"作為依賴bower.json (並保存)。

在我的/app/layout.jade文件中,這是:

body
    // bower:js
    // endbower

被替換為:

body
    // bower:js
    script(src='bower_components/jquery/dist/jquery.js')
    // endbower

如果要使用build:js而不將({app,.tmp})到所有塊中,則在html任務中,將app.tmp都添加到源中。

您的.js.css位於app目錄中,因此當您將源更改為.tmp/*.html而不是app/*.html ,您的兩個$ .filters找不到任何文件。

要解決此問題,請將gulp.src()為包含兩個路徑的數組。

更換:

gulp.task('html', ['templates', 'styles', 'scripts'], function () {
    var jsFilter = $.filter('**/*.js');
    var cssFilter = $.filter('**/*.css');

    return gulp.src('.tmp/*.html')
    ...

帶有:

gulp.task('html', ['templates', 'styles', 'scripts'], function () {
    var jsFilter = $.filter('**/*.js');
    var cssFilter = $.filter('**/*.css');

    return gulp.src(['app/*.html', '.tmp/*.html'])
    ...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM