摘要:到這里,已經(jīng)可以取出我們要打包的項目代碼了,下面開始進(jìn)行具體打包工作。這里用到的插件,代碼如下完整打包經(jīng)過以上,一個完整的如下流程圖
打包流程簡介
本次打包大致過程是checkout出想要打包的git版本(可以是tag,也可以是branchName),然后依次讀取項目中的html、less、js進(jìn)行壓縮合并等操作,復(fù)制項目中所用到的第三方庫到輸出目錄(即plugins中的插件,比如lodash、echarts等,前邊壓縮合并的js是自己寫的js),然后打zip包,發(fā)送至目的地。
在gulp腳本中聲明下載的gulp插件,即:
var gulp = require("gulp"), concat = require("gulp-concat"), less = require("gulp-less"), minifyCss = require("gulp-minify-css"), minify = require("gulp-minify"), zip = require("gulp-zip"), moment = require("moment"), ftp = require("gulp-ftp"), git = require("gulp-git"), runSequence = require("run-sequence"), argv = require("minimist")(process.argv.slice(2)), del = require("del"), uglify = require("gulp-uglify"), htmlmin = require("gulp-htmlmin"), ngAnnotate = require("gulp-ng-annotate");統(tǒng)一配置路徑
比如項目結(jié)構(gòu)圖如下:
那么這里配置的輸入輸出路徑即為:
路徑以gulpfile.js為參考位置。
var path={ input:{ html:["src/app/*.html"], js:["src/app/js/*.js"], less:["src/app/less/*.less"], image:["src/app/image/*"], fonts:["src/app/fonts/*"], plugins:["src/plugins/**/*"] } output:{ dist:"dist", plugins:"dist/plugins" } }
如果不想要某文件,比如不想去壓縮html1.html
var path={ input:{ html:["src/app/*.html","!src/app/html1.html"], } }
"!"后面也可以跟某一類型文件,或者直接指定某文件夾。
使用gulp-git如果想打包git版本庫中的某一個版本,或者某一個分支,就需要用到git.checkout,但是在checkout之前,需要首先提交git版本,如果在git-bash下,會進(jìn)行如下操作。
git add . git commit -m “there are some comments”
在gulp中也一樣,我們需要編寫如下代碼
gulp.task("commit", function(){ return gulp.src("./demo/**/*") .pipe(git.add()) .pipe(git.commit()); });
commit的必要性是如果在本地工作空間修改,而沒有提交到本地倉庫的話,代碼有可能會丟。
上面這段代碼也可以不寫,不寫的話,就需要每次執(zhí)行g(shù)ulp腳本之前,手動commit一下,總之,commit很重要。。。
接下來,就要checkout出相關(guān)版本了,因為不能確定打那個一版本的包,所有這里可能需要用命令行手動去指定一個版本,這里就用到了上篇提到的一個插件,minimist,插件具體就不在介紹了,這里直接上checkout的代碼。
gulp.task("checkout",[commit], function () { gitTag = argv.tag; git.checkout(gitTag, function (err) { if (err) throw err; }); })
其中argv.tag就是用了minimist獲取的,命令行我會這樣輸入。
gulp publish --tag v1.0.0
這種是指定tag的方式,還可以給gitTag 變量加一個默認(rèn)值,即
gitTag = argv.tag||defaultValue;
這個defaultValue可以寫死一個版本,也可以在每次commit的時候生成一個tag,gulp-git也有creat-tag的功能,這個方案我是沒有去嘗試的,理論上應(yīng)該沒啥問題,沒有去用的主要原因是,感覺這樣打的tag有點多了,所以還是手動去給一個tag。
到這里,已經(jīng)可以取出我們要打包的項目代碼了,下面開始進(jìn)行具體打包工作。
壓縮合并壓縮合并,簡單來說,就是指定需要處理的資源,然后調(diào)用相關(guān)函數(shù),輸出到某目錄,等待下一步處理。
這里難度不大,直接上代碼:
壓縮html
gulp.task("html", function () { var options = { removeComments: true, collapseWhitespace: true, collapseBooleanAttributes: true, removeEmptyAttributes: true, removeScriptTypeAttributes: true, removeStyleLinkTypeAttributes: true, minifyJS: true, minifyCSS: true }; return gulp.src(config.input.html) .pipe(htmlmin(options)) .pipe(gulp.dest(config.output.dist))//gulp dest是輸出 });
壓縮合并JS
gulp.task("js", function (done) { return gulp.src(config.input.js) .pipe(ngAnnotate({single_quotes: true})) .pipe(uglify()) .pipe(concat("index.min.js")) .pipe(gulp.dest(config.output.dist)) });
編譯壓縮合并less
gulp.task("less", function () { return gulp.src(config.input.less) .pipe(less()) .pipe(minifyCss()) .pipe(concat("index.min.css")) .pipe(gulp.dest(config.output.dist)); });
復(fù)制第三方插件
gulp.task("copy", function (done) { return gulp.src(config.input.plugins) .pipe(gulp.dest(config.dist.plugins); });
正常情況進(jìn)行過上面4步操作最后,會得到這樣的結(jié)果:
經(jīng)過合并壓縮等操作之后,項目會自動生成dist目錄,dist目錄下即為打包生成的各種文件,接下來的目標(biāo)是將dist目錄下的所有文件打成一個zip包,代碼如下:
gulp.task("zip_new", function () { var timeStamp = moment().format("YYYY-MM-D_HH-mm-ss_"); return gulp.src(config.input.zip) .pipe(zip("dist_" + timeStamp + ".zip")) .pipe(gulp.dest(config.output.dist)); });
moment是一個獲取時間的插件,可以給打的包一個時間來標(biāo)記,這個加不加都無所謂,zip方法里面就是zip包的名稱,隨意命名。
發(fā)送至指定服務(wù)器將zip包打好之后便可以發(fā)送zip包到某服務(wù)器了,代碼如下:
gulp.task("ftp", function () { gulp.src("dist_zip/*") .pipe(ftp({ host: "someHost", port: 21, //user: "anonymous", //pass:null, remotePath: "somePath/" })); });一鍵打包
至這里,打包就全部完成了,下面要做的就是把他們連起來,這里用到上篇提到的插件,run-sequence,插件用法如下:
gulp.task("publish", function (callback) { runSequence(["html", "js","less", "copy"],"zip_new",ftp,callback); });
這里有兩點需要注意:
1.run-sequence里面的任務(wù),按順序執(zhí)行(方括號里面4個任務(wù),算作一個任務(wù)),而且前一個跑完才會跑后一個,方括號里的是異步的,即不一定哪個先完成。
2.要想達(dá)到第一點里面的同步執(zhí)行(一個任務(wù)完成才開始下一個),一定要保證前面的所有任務(wù),即除了ftp任務(wù),其余的方法一定要是return出來的,即:
正確寫法:
gulp.task("js", function (done) { return gulp.src(config.input.js) .pipe(ngAnnotate({single_quotes: true})) .pipe(uglify()) .pipe(concat("index.min.js")) .pipe(gulp.dest(config.output.dist)) });
錯誤寫法:
gulp.task("js", function (done) { gulp.src(config.input.js) .pipe(ngAnnotate({single_quotes: true})) .pipe(uglify()) .pipe(concat("index.min.js")) .pipe(gulp.dest(config.output.dist)) });
前邊都要這樣寫,最后一項不加return,在本例中,即ftp的方法不用返回。
清理dist目錄寫到這里,還有一個問題,就是沒有對文件夾進(jìn)行清理,這也是比較重要的,在每一次開始打包工作之前,我們需要清理dist目錄,以保證下一次打包不會被上一次打包的文件“污染”。這里用到gulp-del的插件,代碼如下:
gulp.task("clean",function(){ return del(config.output.dist); })完整打包review
經(jīng)過以上,一個完整的run-sequence如下:
gulp.task("publish", function (callback) { runSequence("clean","checkout",["html", "js","less", "copy"],"zip_new","ftp",callback); });
流程圖:
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/80795.html
摘要:本文特此給大家介紹下如何使用配合來構(gòu)建基于的前端項目。最后,在目錄下會生成最終的項目文件。執(zhí)行單元測試本例中使用進(jìn)行單元測試。 隨著React、Angular2、Redux等前沿的前端框架越來越流行,使用webpack、gulp等工具構(gòu)建前端自動化項目也隨之變得越來越重要。鑒于目前業(yè)界普遍更流行使用webpack來構(gòu)建es6(ECMAScript 2015)前端項目,網(wǎng)上的相關(guān)教程也比...
摘要:前言與是目前圈子內(nèi)比較活躍的前端構(gòu)建工具。對于初學(xué)者來說,對這二者往往容易認(rèn)識不清,今天,就從事件的源頭,說清楚與。它可以將許多松散的模塊按照依賴和規(guī)則打包成符合生產(chǎn)環(huán)境部署的前端資源。打包后形成的文件出口。 前言:Webpack 與 gulp是目前圈子內(nèi)比較活躍的前端構(gòu)建工具。網(wǎng)上有很多二者比較的文章,面試中也會經(jīng)常遇到gulp,Webpack的區(qū)別這樣的問題。對于初學(xué)者來說,對這二...
摘要:概述最近研究了下工作流,先說一下我司的情況,我司現(xiàn)在是端用直出,用構(gòu)建,部分就不進(jìn)行描述了,因為網(wǎng)上的構(gòu)建方法都是很成熟的了。 概述 最近研究了下工作流,先說一下我司的情況,我司現(xiàn)在是pc端用php直出,h5用vuejs構(gòu)建,vuejs部分就不進(jìn)行描述了,因為網(wǎng)上的構(gòu)建方法都是很成熟的了。以下是php直出,需要向后臺同學(xué)提供html文件的構(gòu)建方法。調(diào)試都是在本地調(diào)試的,調(diào)試完成后打包生...
摘要:自動化打包上文章概述本文分為上下兩篇,上篇主要介紹一些常用的插件也是此次打包主要用的插件,而下篇主要以一個項目為例,從本地出合適的版本,壓縮合并到最后打成包,發(fā)送至指定目錄,做一個全面的演示。 gulp自動化打包(上) 文章概述 本文分為上下兩篇,上篇主要介紹一些常用的gulp插件(也是此次打包主要用的gulp插件),而下篇主要以一個demo項目為例,從本地checkout出合適的g...
摘要:生成的文件如下由于給文件添加了哈希值,所以每次編譯出來的和都是不一樣的,這會導(dǎo)致有很多冗余文件,所以我們可以每次在生成文件之前,先將原來的文件全部清空。中也有做這個工作的插件,因此我們可以在編譯壓縮添加哈希值之前先將原文將清空。 原文鏈接:http://mrzhang123.github.io/2016/09/07/gulpUse/項目鏈接:https://github.com/MrZ...
閱讀 2846·2023-04-26 02:23
閱讀 1594·2021-11-11 16:55
閱讀 3155·2021-10-19 11:47
閱讀 3370·2021-09-22 15:15
閱讀 1984·2019-08-30 15:55
閱讀 1045·2019-08-29 15:43
閱讀 1299·2019-08-29 13:16
閱讀 2203·2019-08-29 12:38