gulp配置

Gulp.js 是一個自動化構建工具,開發者能夠使用它在項目開發過程當中自動執行常見任務。css

整個文件項目的目錄以下圖:html

一、全局安裝gulp:npm install --global gulpnpm

二、安裝項目開發依賴:npm install --save-dev gulpjson

三、安裝package.json:yarn init -ygulp

配置package.json文件:less

{
  "name": "gulp",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "iceStone <ice@wedn.net> (http://wedn.net/)",
  "license": "ISC",
  "devDependencies": {
    "browser-sync": "^2.11.1",
    "del": "^2.2.0",
    "gulp": "^3.9.0",
    "gulp-autoprefixer": "^3.1.0",
    "gulp-base64": "^0.1.3",
    "gulp-concat": "^2.6.0",
    "gulp-cssnano": "^2.1.0",
    "gulp-font-spider": "^0.3.6",
    "gulp-htmlmin": "^1.3.0",
    "gulp-imagemin": "^3.3.0",
    "gulp-less": "^3.0.5",
    "gulp-rev": "^7.1.2",
    "gulp-rev-collector": "^1.2.2",
    "gulp-uglify": "^3.0.0"
  }
}

 

四、建立gulpfile.js:touch gulpfile.jside

配置gulpfile.js文件:工具

var gulp = require('gulp');
var less = require('gulp-less');
var cssnano = require('gulp-cssnano');
var base64 = require('gulp-base64');
var imagemin = require('gulp-imagemin');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var htmlmin = require('gulp-htmlmin');
var browserSync = require('browser-sync');
var rev = require('gulp-rev');
var revCollector = require('gulp-rev-collector');

var fontSpider = require( 'gulp-font-spider' );

gulp.task('css',['images'],function() {
  gulp.src(['src/css/*.less', '!src/css/_*.less'])
     .pipe(less())
       .pipe(base64({
          extensions: ['png', /\.jpg#datauri$/i],
          exclude:    [/\.server\.(com|net)\/dynamic\//, '--live.jpg'],
          maxImageSize: 800*1024,
          debug: true
      }))
    .pipe(concat('style.min.css'))
    .pipe(cssnano())
    .pipe(gulp.dest('dist/css'))
    .pipe(browserSync.reload({
      stream: true
    }));
});


gulp.task('images',function(){
    gulp.src('./src/images/*')
     .pipe(gulp.dest('dist/images'))
});

gulp.task('js', function() {
  gulp.src('src/js/*.js')
    .pipe(concat('all.js'))
    .pipe(uglify())
    .pipe(gulp.dest('dist/js'))
    .pipe(browserSync.reload({
      stream: true
    }));
});


gulp.task('html', function() {
  gulp.src('src/*.html')
    .pipe(htmlmin({
      collapseWhitespace: true,
      removeComments: true
    }))
    .pipe(gulp.dest('dist'))
    .pipe(browserSync.reload({
      stream: true
    }));
});

gulp.task('md5',function(){
    gulp.src('dist/css/*.css')
      .pipe(rev())
      .pipe(gulp.dest('dist/css/'))
      .pipe(rev.manifest())
      .pipe(gulp.dest('dist/config'))
})

gulp.task('top',function(){
    gulp.src(['./dist/config/*.json', './dist/*.html'])
      .pipe(revCollector())
      .pipe(gulp.dest('./dist/'))
})

gulp.task('fontspider', function() {
     return gulp.src('./src/index.html')
   .pipe(fontSpider())

        // .pipe(fontSpider({
    //         silent: false,
    //         backup: false,
    // }))
    .pipe(gulp.dest('./dist/font'))
});



gulp.task('server', function() {
  browserSync({
    server: {
      baseDir: ['dist']
    },
  }, function(err, bs) {
    console.log(bs.options.getIn(["urls", "local"]));
  });

  gulp.watch('src/*.html',['html']);
  gulp.watch('src/css/*.less',['css']);
  gulp.watch('src/js/*.js',['js']);
  gulp.watch('src/fonts/*.otf', ['fontspider'])

});

 

五、運行gulp:gulp serverui

夢想仍是要有,萬一實現了呢?url

相關文章
相關標籤/搜索