一、首先全局安裝gulpcss
全局安裝就不作介紹了html
初學gulp,終於把經常使用的配置,api,語法弄明白了!git
gulp插件地址:http://gulpjs.com/plugins
gulp官方網址:http://gulpjs.com
gulp 官方API:https://github.com/gulpjs/gulp/blob/master/docs/API.mdgithub
項目的目錄結構應該是npm
1 D:. 2 └─文件名 3 ├─src 4 │ ├─css 5 │ ├─fonts 6 │ ├─images 7 │ └─js 8 └─dist 9 ├─css 10 ├─fonts 11 ├─images 12 └─js 13 gulpfile.js 14 package.json
src是json
二、新建一個package.jsongulp
1 npm init
命令行中會出現vim
1 Press ^C at any time to quit. 2 name: (a1) 3 version: (1.0.0) 4 description: 5 entry point: (index.js) 6 test command: 7 git repository: 8 keywords: 9 author: 10 license: (ISC)
填各類信息,填完出現下面api
1 { 2 "name": "a1",//項目名稱(必填) 3 "version": "1.0.0",//項目版本(必填) 4 "description": "a test",//項目描述(必填) 5 "main": "gulpfile.js",//入口文件 6 "test command" //測試命令 7 "git repository" //git 地址 8 "keywords" //關鍵字 9 "scripts": { 10 "test": "echo \"Error: no test specified\" && exit 1" 11 }, 12 "author": "",//做者 13 "license": "ISC" //許可信息 14 } 15 16 Is this ok? (yes)
爲了能正常使用,咱們還得本地安裝gulp:測試
1 npm install gulp --save-dev;
全局安裝gulp是爲了執行gulp任務,本地安裝gulp則是爲了調用gulp插件的功能。
以後就是須要什麼就安裝什麼插件了
1 npm install gulp-htmlmin gulp-imagemin imagemin-pngcrush gulp-minify-css gulp-uglify gulp-concat gulp-rename gulp-notify --save-dev
安裝js校驗插件
npm install --save-dev jshint gulp-jshint
–save:將保存配置信息至package.json
-dev:保存至package.json的devDependencies節點,不指定-dev將保存至dependencies節點;
三、建立gulpfile.js文件
1 vim gulpfile.js
輸入代碼
1 // 引入 gulp及組件 2 //插件的引入方法 和任務創建方法參照gulp的官網插件 3 var gulp = require('gulp'), 4 autoprefixer = require('gulp-autoprefixer'), 5 minifycss = require('gulp-minify-css'), //壓縮css 6 jshint = require('gulp-jshint'), //js代碼校驗 7 uglify = require('gulp-uglify'), //壓縮JS 8 imagemin = require('gulp-imagemin'), //壓縮圖片 9 rename = require('gulp-rename'), //合併js文件 10 concat = require('gulp-concat'), 11 notify = require('gulp-notify'), 12 cache = require('gulp-cache'), 13 livereload = require('gulp-livereload'), 14 del = require('del'); 15 htmlmin = require('gulp-htmlmin');//壓縮html代碼 16 //創建任務: Styles 17 gulp.task('styles', function() { 18 return gulp.src('src/styles/*.css') 19 .pipe(rename({ 20 suffix: '.min' 21 })) 22 .pipe(minifycss()) 23 .pipe(gulp.dest('dist/styles')) 24 .pipe(notify({ 25 message: 'Styles task complete' 26 })); 27 }); 28 //創建任務: htmlmin 29 gulp.task('htmlmin', function() { 30 // src/**/*.html 這個表明的是src下邊的html文件以及他的子文件下的全部的html文件 31 return gulp.src('src/*.html') 32 .pipe(rename({ 33 suffix: 'min' 34 })) 35 .pipe(htmlmin({collapseWhitespace: true})) 36 .pipe(gulp.dest('dist')) 37 .pipe(notify({ 38 message: ' task complete' 39 })); 40 }); 41 // Scripts 42 gulp.task('scripts', function() { 43 return gulp.src('src/scripts/**/*.js') 44 .pipe(jshint()) 45 .pipe(jshint.reporter('default')) 46 .pipe(concat('main.js')) 47 .pipe(rename({ 48 suffix: '.min' 49 })) 50 .pipe(uglify()) 51 .pipe(gulp.dest('dist/scripts')) 52 .pipe(notify({ 53 message: 'Scripts task complete' 54 })); 55 }); 56 // Images 57 gulp.task('images', function() { 58 return gulp.src('src/images/**/*') 59 .pipe(cache(imagemin({ 60 optimizationLevel: 3, 61 progressive: true, 62 interlaced: true 63 }))) 64 .pipe(gulp.dest('dist/images')) 65 .pipe(notify({ 66 message: 'Images task complete' 67 })); 68 }); 69 // Clean 任務執行前,先清除以前生成的文件 70 gulp.task('clean', function(cb) { 71 del(['dist/assets/css', 'dist/assets/js', 'dist/assets/img'], cb) 72 }); 73 // Default task 設置默認任務 74 gulp.task('default', ['clean'], function() { 75 gulp.start('styles', 'scripts', 'images'); 76 }); 77 // 監聽文件: Watch 78 gulp.task('watch', function() { 79 // Watch .scss files 80 gulp.watch('src/styles/**/*.css', ['styles']); 81 // Watch .js files 82 gulp.watch('src/scripts/**/*.js', ['scripts']); 83 // Watch image files 84 gulp.watch('src/images/**/*', ['images']); 85 // Create LiveReload server 86 livereload.listen(); 87 // Watch any files in dist/, reload on change 88 gulp.watch(['dist/**']).on('change', livereload.changed); 89 });
四、查看js 和 json 文件
json 文件如今應該是
1 { 2 "name": "gulp-learn", 3 "version": "1.0.0", 4 "description": "", 5 "main": "gulpfile.js", 6 "scripts": { 7 "test": "echo \"Error: no test specified\" && exit 1" 8 }, 9 "author": "haonan", 10 "license": "ISC", 11 "devDependencies": { 12 "gulp": "^3.9.1", 13 "gulp-clean-css": "^3.0.2", 14 "gulp-concat": "^2.6.1", 15 "gulp-htmlmin": "^3.0.0", 16 "gulp-imagemin": "^3.1.1", 17 "gulp-jshint": "^2.0.4", 18 "gulp-minify-css": "^1.2.4", 19 "gulp-notify": "^3.0.0", 20 "gulp-rename": "^1.2.2", 21 "gulp-uglify": "^2.0.1", 22 "imagemin-pngcrush": "^5.0.0", 23 "jshint": "^2.9.4" 24 "package.json" 25L, 594C
五、開始運行壓縮
js文件中的
gulp.task('images', function() {
task也就是任務後邊的 '' 裏面是什麼就表明是什麼方法,在終端運行
gulp 方法 就行