为什么在Gulp / Vinyl-ftp上传bootstrap.min.css之前我必须保存两次LESS源文件?

时间:2017-07-18 16:09:04

标签: javascript twitter-bootstrap gulp vinyl-ftp

我有一个gulpfile.js,内容如下。我希望它生成bootstrap.min.css并在将LESS文件保存在/ less文件夹中后立即上传到服务器。问题是:只有在保存文件两次后,才会上传最终结果。我想我做错了什么。

以下是我正在使用的代码:

    var gulp = require ('gulp'),
    //cleanCSS = require('gulp-clean-css'),
    autoprefixer = require('gulp-autoprefixer'),
    less = require('gulp-less'),
    plumber = require('gulp-plumber'),
    sourcemaps = require('gulp-sourcemaps'),
    rename = require('gulp-rename'),
    gutil = require('gulp-util'),
    ftp = require ('vinyl-ftp');


// Styles Task using LESS
// Uglifies
gulp.task('less', function(){
    gulp.src('../less/bootstrap.less')
    .pipe(plumber())
    .pipe(less())
    .pipe(autoprefixer({}))
    .pipe(sourcemaps.init())
    .pipe(rename({suffix: '.min'}))
    .pipe(sourcemaps.write('.'))
    .pipe(gulp.dest('../css/'));
});

    // Vinyl FTP 
    gulp.task( 'deploy', function () {

        var conn = ftp.create( {
            host:     '[ftp-address]',
            user:     '[ftp-user]',
            password: '[password]',
            parallel: 10,
            log:      gutil.log
        } );

        var globs = ['../css/bootstrap.min.css'];



        return gulp.src( globs, { base: '.', buffer: false } )
            .pipe( conn.newer( '/public_html/[folder/on/server]/css/' ) ) // only upload newer files
            .pipe( conn.dest( '/public_html/[folder/on/server]/css/' ) );

    } );
// Watch Task
// Watches JS
gulp.task('watch', function(){
    gulp.watch('../less/**/*.less', ['less','deploy']);
});

gulp.task ('default', ['less','deploy','watch']);

由于我不是javascript / npm / gulp / node.js专家,我很茫然。这让我觉得我需要两次保存较少的文件。 任何人都可以识别错误吗?如果您需要更多信息,请随时询问。

感谢名单,

汤姆

1 个答案:

答案 0 :(得分:1)

您有两个可能的问题:

  1. 在您的“少”中回报。任务,所以gulp会知道它已经完成。
  2. 你不能在你的手表中假设'以任何特定顺序运行/完成[' less',' deploy']的任务。它们是并行运行的,因此顺序可能会有所不同。与'默认'相同任务。
  3. 最好让您的部署'任务取决于“少”'任务ala

    gulp.task( 'deploy', ['less'], function () {
    

    并改为

     gulp.watch('../less/**/*.less', ['deploy']);
    
    
    // Styles Task using LESS
    // Uglifies
    gulp.task('less', function(){
    // add the return to the next line
      return gulp.src('../less/bootstrap.less')
      .pipe(plumber())
      .pipe(less())
      .pipe(autoprefixer({}))
      .pipe(sourcemaps.init())
      .pipe(rename({suffix: '.min'}))
      .pipe(sourcemaps.write('.'))
      .pipe(gulp.dest('../css/'));
    });
    
    // Watch Task
    // Watches JS
    gulp.task('watch', function(){
      gulp.watch('../less/**/*.less', ['deploy']);
    });
    
    // Vinyl FTP 
    gulp.task( 'deploy', ['less'], function () {
    
        var conn = ftp.create( {
            host:     '[ftp-address]',
            user:     '[ftp-user]',
            password: '[password]',
            parallel: 10,
            log:      gutil.log
        } );
    
        var globs = ['../css/bootstrap.min.css'];
    
        return gulp.src( globs, { base: '.', buffer: false } )
            .pipe( conn.newer( '/public_html/[folder/on/server]/css/' ) ) // only upload newer files
            .pipe( conn.dest( '/public_html/[folder/on/server]/css/' ) );
    
    } );