摘要:簡介使用搭建一個傳統(tǒng)的多頁面前端項目的開發(fā)環(huán)境支持編譯支持支持開發(fā)環(huán)境和打包生成支持文件變動自動刷新瀏覽器,是熱更新改動無需刷新瀏覽器即可更新支持新增文件沒無需重啟,即可改動自動刷新瀏覽器支持命令生成雪碧圖和對應(yīng)支持,使用的插件是支持
gulp-easy github 1、簡介
使用gulp搭建一個傳統(tǒng)的多頁面前端項目的開發(fā)環(huán)境
支持pug scss es6編譯支持
支持開發(fā)環(huán)境和打包生成sourceMap
支持文件變動自動刷新瀏覽器,css是熱更新(css改動無需刷新瀏覽器即可更新)
支持新增文件沒無需重啟gulp,即可改動自動刷新瀏覽器
支持命令生成雪碧圖和對應(yīng)css
支持eslint,使用的eslint插件是eslint-config-alloy
支持打包html,css,js圖片壓縮,css中小圖片轉(zhuǎn)base64
支持css,js文件版本hash值,文件無變動則版本hash不會改變,更好利用緩存
支持html中的css,js,img路徑添加cdn域名前綴,css中的圖片鏈接建議使用相對路徑
支持代理,便于跨域調(diào)試
2、如何使用 2.1 下載項目(1) git clone https://github.com/lfyfly/gulp-easy.git或者下載 zip包
(2)刪除項目下的因此目錄.git文件夾,這是我的commit記錄,所以刪除
(3)npm install 安裝依賴
(4)npm run dev
2.2 命令 npm run dev進入開發(fā)模式
npm run build打包命令
npm run start打包并且以dist為根目錄開啟服務(wù)器查看效果
npm run sp把根目錄下的sprites文件夾下的子目錄內(nèi)的所有文件夾中的png和jpg的圖片,以子文件夾目錄為單位生產(chǎn)雪碧圖,文件名為子目錄名
npm run linteslint檢測
npm run fixeslint修復(fù)
3、 約定的目錄src是源碼目錄,可以通過config.srcPath進行配置,以下src只目錄只是個例子,代表源碼目錄3.1 src/static
靜態(tài)文件目錄
3.2 src/static/_vendor第三方j(luò)s,css,iconfont等
3.3 src/_scssscss模塊目錄,里面的.scss文件不會被多帶帶編譯成css文件
3.4src/_pugpug模塊目錄,里面的.pug文件不會被多帶帶編譯成html文件
4.5 src/_modules該目錄里面的.pug,.scss文件不會被多帶帶編譯成html文件
4、功能配置文件根目錄下的config.js
module.exports = { srcPath: "src", pug: true, scss: true, babel: true, tmpPath: "node_modules/__tmp__", build: { htmlmin: true, cssmin: true, jsmin: true, base64: 10 * 1024, // (bytes) 使用css中圖片使用相對路徑,否者無效 cssSourcemap: true, jsSourcemap: true, cdn: "http://your/cdn/url/", versionHash: true, // 版本hash }, proxyTable: { "/api": "http://localhost:3000", "/hehe": { target: "http://localhost:3000", pathRewrite: { // 地址重寫 "^/hehe": "/api" } } } }5、功能配置項詳解
如不需要使用某個配置項目,直接將其注釋即可srcPath
配置目錄源文件目錄,默認為"src"
pug值為true時,會開啟對src目錄內(nèi)所有的.pug文件(除src/_pug/外)編譯成html
src/_pug作為pug的模塊目錄,不會被多帶帶編譯為html文件
scss值為true時,會開啟對src內(nèi)所有的.scss,.sass文件(除src/_scss外)編譯成scss
src/_scss/作為scss的模塊目錄,不會被多帶帶編譯為css文件
babel值為true時,會開啟對src目錄內(nèi)所有的.js文件(除src/static/vendor/外)編譯成es5
babel配置文件,根目錄下.babelrc文件
tmpPath默認值為 "node_modules/__tmp__"
npm run dev作為.pug,.scss,.js文件編譯的臨時文件目錄,和src同為靜態(tài)文件目錄,且優(yōu)先級高于src目錄
browserSync.init({ server: { baseDir: [config.tmpPath, "src"], }, middleware, port: 9000, online: false })
編譯后文件訪問:src/static/public/public.scss在html的訪問路徑為/static/public/public.css
每次運行npm run dev config.tmpPath都會被清理
打包配置項config.build | 描述 |
---|---|
htmlmin | 值為true時開啟html壓縮 |
cssmin | 值為true時開啟css壓縮 |
jsmin | 值為true時開啟js壓縮 |
base64 | Number類型,單位(bytes),當css圖片大小小于該值時將轉(zhuǎn)base64 css中圖片地址必須為相對路徑才會生效 |
cssSourcemap | 值為true時,生成cssSourcemap文件 |
jsSourcemap | 值為true時,生成jsSourcemap文件 |
cdn | 值為你的cdn地址 |
versionHash | 值為true時,生成css js文件版本hash值 |
proxyTable | 代理配置,http-proxy-middleware |
proxyTable: { "/api": "http://localhost:3000", "/hehe": { target: "http://localhost:3000", pathRewrite: { // 地址重寫 "^/hehe": "/api" } } }6、項目目錄構(gòu)建示例 6.1 Deom-0 見src目錄
使用html,css,js構(gòu)建項目
6.2 Deom-1 見src-1目錄使用pug(可選用),scss,js構(gòu)建項目
將config.srcPath值設(shè)為src-1即可切換到該項目
推薦使用sea.js或require.js進行模塊管理
7.2 為什么不在gulp中配置eslint?推薦使用瀏覽器插件進行提示,還可以配置保存時自動修復(fù)eslint
7.3 js中如何判斷是否為開發(fā)模式// 當前環(huán)境為開發(fā)環(huán)境 var isDev = !!document.getElementById("__bs_script__")
注意: isDev只能在body標簽內(nèi)的js中這樣獲取,或者在DOMContenLoaded或load事件回調(diào)中初始化 isDev
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96203.html
摘要:從到再到搭建編寫構(gòu)建一個前端項目選擇現(xiàn)成的項目模板還是自己搭建項目骨架搭建一個前端項目的方式有兩種選擇現(xiàn)成的項目模板自己搭建項目骨架。使用版本控制系統(tǒng)管理源代碼項目搭建好后,需要一個版本控制系統(tǒng)來管理源代碼。 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項目 1. 選擇現(xiàn)成的項目模板還是自己搭建項目骨架 搭建一個前端項目的方式有兩種:選擇現(xiàn)成的項目模板、自己搭建項目骨架。 ...
摘要:從到再到搭建編寫構(gòu)建一個前端項目選擇現(xiàn)成的項目模板還是自己搭建項目骨架搭建一個前端項目的方式有兩種選擇現(xiàn)成的項目模板自己搭建項目骨架。使用版本控制系統(tǒng)管理源代碼項目搭建好后,需要一個版本控制系統(tǒng)來管理源代碼。 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項目 1. 選擇現(xiàn)成的項目模板還是自己搭建項目骨架 搭建一個前端項目的方式有兩種:選擇現(xiàn)成的項目模板、自己搭建項目骨架。 ...
摘要:從到再到搭建編寫構(gòu)建一個前端項目選擇現(xiàn)成的項目模板還是自己搭建項目骨架搭建一個前端項目的方式有兩種選擇現(xiàn)成的項目模板自己搭建項目骨架。使用版本控制系統(tǒng)管理源代碼項目搭建好后,需要一個版本控制系統(tǒng)來管理源代碼。 從 0 到 1 再到 100, 搭建、編寫、構(gòu)建一個前端項目 1. 選擇現(xiàn)成的項目模板還是自己搭建項目骨架 搭建一個前端項目的方式有兩種:選擇現(xiàn)成的項目模板、自己搭建項目骨架。 ...
摘要:今天跟大家分享的是關(guān)于目前自己的公司的項目優(yōu)化中所使用到的構(gòu)建工具。在進行基礎(chǔ)鞏固的基礎(chǔ)上,使用構(gòu)建工具可以在開發(fā)的過程中進行部分自動化構(gòu)建,如對頁面的監(jiān)聽,對樣式的編譯,對代碼的壓縮與打包。在使用之前,要先對所需要的依賴進行安裝。 Why? 今天跟大家分享的是關(guān)于目前自己的公司的項目優(yōu)化中所使用到的gulp構(gòu)建工具。目前公司對產(chǎn)品的優(yōu)化決定采用VueJs來進行單頁面開發(fā),無疑這種新的...
閱讀 3991·2021-11-22 15:31
閱讀 2524·2021-11-18 13:20
閱讀 3114·2021-11-15 11:37
閱讀 7043·2021-09-22 15:59
閱讀 747·2021-09-13 10:27
閱讀 3783·2021-09-09 09:33
閱讀 1447·2019-08-30 15:53
閱讀 2570·2019-08-29 15:37