[TOC]
# 準備工作
最開始,當然要先安裝node和npm,然后新建自己的項目(ps:項目名不能是‘gulp’),
然后初始化一下:
npm init -y
生成packge.json
首先我們來看一下項目的目錄結構:
```
如圖:
目錄css、images、js都是你項目原本的文件目錄
而dist目錄以及目錄下的css、images、js目錄就是將文件壓縮后存放到的相應目標目錄
接下來,就可以進入正題了
```
# 安裝gulp
在你的項目目錄下打開命令行界面
首先要全局安裝一下gulp,輸入:
npm i -g gulp
然后,要把gulp安裝到本地:
npm i -D gulp
# 編寫gulpfile.js文件
首先在項目目錄下新建一個gulpfile.js文件:
# 導包
引入所需要的包:
```
var gulp = require('gulp');
var uglify = require('gulp-uglify'); ////用于壓縮js文件
var minifyCSS = require('gulp-minify-css'); ////用于壓縮css文件
var imagemin = require('gulp-imagemin'); ////用于壓縮image文件
gulp-uglify、gulp-minify-css、gulp-imagemin需要在本地安裝一下,
```
同理在項目目錄下打開命令行界面,輸入相應命令:
```
npm i -D gulp-uglify
npm i -D gulp-minify-css
npm i -D gulp-imagemin
```
安裝成功后,繼續在gulpfile.js中寫代碼:
新建壓縮任務
```
/////新建一個‘script’任務 /////用于壓縮js文件
gulp.task('script',function(){
/////找到需要壓縮的文件
gulp.src('js/**/*.js') //// /**/ 表示js目錄下的任意層級的目錄
/////壓縮文件
.pipe(uglify())
/////另存壓縮后文件
.pipe(gulp.dest('dist/js'));
});
```
同理,也可以新建壓縮css、images文件的任務:
```
gulp.task('css',function(){
gulp.src('css/**/*.css')
.pipe(minifyCSS())
.pipe(gulp.dest('dist/css'));
});
gulp.task('images',function(){
gulp.src('images/**/*.*')
.pipe(imagemin({progressive:true}))
.pipe(gulp.dest('dist/images'));
});
```
到此,壓縮的任務就完成了,在命令行界面可以輸入 ‘gulp’ 空格 任務名稱 來執行壓縮,例如:
```
gulp script
```
執行完成后,在dist目錄的相應目錄下可以找到壓縮后的文件
# 自動壓縮任務
在默認情況下,我們每次修改文件都要去執行壓縮任務才能得到壓縮后的文件,
為了方便,我們使用watch方法來新建一個監聽任務,每次修改文件,系統會自動執行壓縮:
```
gulp.task('auto',function(){
////////監聽文件,當文件被修改后自動執行壓縮任務
////////第一個參數:監聽的目標文件
///////第二個參數:監聽到修改后執行的壓縮任務
gulp.watch('js/**/*.js',['script']);
gulp.watch('css/**/*.css',['css']);
gulp.watch('images/**/*.*',['images']);
});
```
默認任務
```
/////////定義默認任務,使用gulp 啟動數組里的所有任務
gulp.task('default',['images','css','script','auto']);
```
新建默認任務后,在命令行執行:
```
gulp
```
即可執行所有數組中的任務
- javascript封裝
- jquery封裝
- layui封裝
- 基本知識
- 匿名函數
- 嚴格模式
- 代碼規范工具
- 使用JSHint和JSLint
- 構建
- Grunt
- gulp
- Gulp使用入門操作十一步壓縮JS
- 注意
- 初級
- 中級
- 高級
- 將es6代碼轉成es5
- 我常用的
- 報錯處理
- 《編寫可維護的Javascript》
- 第1章:基本的格式化
- 縮進層級
- 語句結尾
- 行的長度
- 換行
- 空行
- 命名
- 變量和函數
- 常量
- 構造函數
- 直接量
- 第2章:注釋
- 單行注釋
- 多行注釋
- 使用注釋
- 文檔注釋
- 第3章:語句和表達式
- 花括號的對齊方式
- 塊語句間隔
- switch語句
- 第4章:變量函數運算符
- 變量聲明
- 函數聲明
- 函數調用間隔
- 立即調用函數
- 嚴格的模式
- 相等
- 第5章:UI的松耦合
- 什么是松耦合
- 將javascript從css中抽離
- 將css從javascript中抽離
- 將javascript從html中抽離
- 將html從javascript中抽離
- 第6章:避免使用全局變量
- 全局變量帶來的問題
- 意外的全局變量
- 單全局變量方式
- 零全局變量
- 第7章:事件處理
- 典型用法
- 規則1:隔離應用邏輯
- 規則2:不要分發事件對象
- 第8章:避免“空比較”
- 檢測原始值
- 檢測應用值
- 檢測屬性
- 第9章:將配置數據從代碼中分離出來
- 什么是配置數據
- 抽離配置數據
- 保存配置數據
- 第10章:拋出自定義錯誤
- 錯誤的本質
- 在javascript拋出錯誤
- 拋出錯誤的好處
- 何時拋出錯誤
- try-catch語句
- 錯誤類型
- 第11章:不是你的對象不要動
- 什么是你的
- 原則
- 更好的途徑
- 關于Polyfill的注釋
- 阻止修改
- 第12章:瀏覽器嗅探
- User-Agent嗅探
- 特性檢測
- 避免特性推斷
- 避免瀏覽器推斷
- 應當如何取舍
- 第13章:目錄和文件結構
- 最佳實踐
- 基本結構
- 第14章:Ant
- 安裝
- 配置文件
- 執行構建
- 目標操作的依賴
- 屬性
- Buildr項目
- 第15章:校驗
- 查找文件
- 任務
- 增強的目標操作
- 其他方面的改進
- Buidr任務
- 第16章:文件的合并與加工
- 任務1
- 行尾結束符
- 文件頭和文件尾
- 加工文件
- 第17章:文件的精簡與壓縮
- 文件精簡
- 壓縮
- 第18章:文檔化
- JSDoc Toolkit
- YUI DOC
- 第19章:自動化測試
- YUI Test Selenium引擎
- Yeti
- PhantomJS
- JsTestDriver
- 第20章:組裝到一起
- Javascript編碼風格指南