npm init -y //生成
npm install gulp -g //全局安裝
npm install gulp --save-dev //本地安裝并加入package.json
npm i -D gulp-babel
npm i -D babel-preset-env
npm install babel-core babel-preset-es2015 gulp-babel --save-dev //用于解析es6轉換為es5
npm install browser-sync --save-dev //服務器同步瀏覽
npm install gulp-autoprefixer --save-dev //根據設置瀏覽器版本自動處理瀏覽器前綴
npm install gulp-cache --save-dev //圖片快取,只有更改過得圖片會進行壓縮
npm install gulp-clean --save-dev //清空文件夾
npm install gulp-cssnano --save-dev //壓縮CSS代碼
npm install gulp-htmlmin --save-dev //壓縮html
npm install gulp-if --save-dev //用于判斷
npm install gulp-imagemin --save-dev //圖片壓縮-很慢
npm install gulp-load-plugins --save-dev //自動加載(超級有用 省去一大堆代碼)
npm install gulp-plumber --save-dev //管道工 不會讓錯誤爆出來 繼續執行
npm install gulp-sass --save-dev //預編譯Sass
npm install gulp-size --save-dev //統計管道里面內容的大小的,上面是用它來顯示出壓縮前后的大小用來對比用
npm install gulp-sourcemaps --save-dev //當壓縮的JS出錯,能根據這個找到未壓縮代碼的位置 不會一片混亂代碼
npm install gulp-uglify --save-dev //JS壓縮
npm install uglifyjs-webpack-plugin --save-dev //壓縮報錯指引
npm install gulp-useref --save-dev // 將html引用順序的CSS JS 變成一個文件 例如:<!-- build:js scripts/main.js --> <script src="1.js"></script><script src="2.js"></script><!--endbuild--> 最后變成<script src="main.js"></script>
npm install gulp-rev-append --save-dev //html引用添加版本號
npm install main-bower-files --save-dev //找到bower.json里配置的 overrides 下配置的main下的路徑
npm install wiredep --save-dev //在.html文件會把默認bower.json的配置自動注入到下面標簽中去 <!-- bower:js --> <!-- endbower --> <!-- bower:css--> <!-- endbower -->
或者直接(注:我一大堆運行會報錯,于是像上邊一個一個運行):
npm install babel-core babel-preset-es2015 browser-sync gulp gulp-autoprefixer gulp-babel gulp-cache gulp-clean gulp-cssnano gulp-htmlmin gulp-if gulp-imagemin gulp-load-plugins gulp-plumber gulp-sass gulp-size gulp-sourcemaps gulp-uglify gulp-useref gulp-rev-append main-bower-files wiredep --save-dev
bower init //新建bower.json
bower install jquery bootstrap-sass --save-dev //安裝jquery bootstrap
- 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編碼風格指南