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