资讯专栏INFORMATION COLUMN

gulp自动化打包(下)

Salamander / 2391人阅读

摘要:到这里,已经可以取出我们要打包的项目代码了,下面开始进行具体打包工作。这里用到的插件,代码如下完整打包经过以上,一个完整的如下流程图

打包流程简介

本次打包大致过程是checkout出想要打包的git版本(可以是tag,也可以是branchName),然后依次读取项目中的html、less、js进行压缩合并等操作,复制项目中所用到的第三方库到输出目录(即plugins中的插件,比如lodash、echarts等,前边压缩合并的js是自己写的js),然后打zip包,发送至目的地。

开始编写gulp脚本 声明gulp插件

在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");
统一配置路径

比如项目结构图如下:

那么这里配置的输入输出路径即为:
路径以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下,会进行如下操作。

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的必要性是如果在本地工作空间修改,而没有提交到本地仓库的话,代码有可能会丢。
上面这段代码也可以不写,不写的话,就需要每次执行gulp脚本之前,手动commit一下,总之,commit很重要。。。

接下来,就要checkout出相关版本了,因为不能确定打那个一版本的包,所有这里可能需要用命令行手动去指定一个版本,这里就用到了上篇提到的一个插件,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 变量加一个默认值,即

 gitTag = argv.tag||defaultValue;

这个defaultValue可以写死一个版本,也可以在每次commit的时候生成一个tag,gulp-git也有creat-tag的功能,这个方案我是没有去尝试的,理论上应该没啥问题,没有去用的主要原因是,感觉这样打的tag有点多了,所以还是手动去给一个tag。

到这里,已经可以取出我们要打包的项目代码了,下面开始进行具体打包工作。

压缩合并

压缩合并,简单来说,就是指定需要处理的资源,然后调用相关函数,输出到某目录,等待下一步处理。
这里难度不大,直接上代码:
压缩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));
});

复制第三方插件

gulp.task("copy", function (done) {
 return gulp.src(config.input.plugins)
    .pipe(gulp.dest(config.dist.plugins);
});

正常情况进行过上面4步操作最后,会得到这样的结果:

打zip包

经过合并压缩等操作之后,项目会自动生成dist目录,dist目录下即为打包生成的各种文件,接下来的目标是将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是一个获取时间的插件,可以给打的包一个时间来标记,这个加不加都无所谓,zip方法里面就是zip包的名称,随意命名。

发送至指定服务器

将zip包打好之后便可以发送zip包到某服务器了,代码如下:

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里面的任务,按顺序执行(方括号里面4个任务,算作一个任务),而且前一个跑完才会跑后一个,方括号里的是异步的,即不一定哪个先完成。
2.要想达到第一点里面的同步执行(一个任务完成才开始下一个),一定要保证前面的所有任务,即除了ftp任务,其余的方法一定要是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目录

写到这里,还有一个问题,就是没有对文件夹进行清理,这也是比较重要的,在每一次开始打包工作之前,我们需要清理dist目录,以保证下一次打包不会被上一次打包的文件“污染”。这里用到gulp-del的插件,代码如下:

gulp.task("clean",function(){
  return del(config.output.dist);
})
完整打包review

经过以上,一个完整的run-sequence如下:

gulp.task("publish", function (callback) {
  runSequence("clean","checkout",["html", "js","less", "copy"],"zip_new","ftp",callback);
});

流程图:

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/80795.html

相关文章

  • 基于 Gulp + Browserify 构建 ES6 环境动化前端项目

    摘要:本文特此给大家介绍下如何使用配合来构建基于的前端项目。最后,在目录下会生成最终的项目文件。执行单元测试本例中使用进行单元测试。 随着React、Angular2、Redux等前沿的前端框架越来越流行,使用webpack、gulp等工具构建前端自动化项目也随之变得越来越重要。鉴于目前业界普遍更流行使用webpack来构建es6(ECMAScript 2015)前端项目,网上的相关教程也比...

    yuanxin 评论0 收藏0
  • Javascript五十问——从源头细说Webpack与Gulp

    摘要:前言与是目前圈子内比较活跃的前端构建工具。对于初学者来说,对这二者往往容易认识不清,今天,就从事件的源头,说清楚与。它可以将许多松散的模块按照依赖和规则打包成符合生产环境部署的前端资源。打包后形成的文件出口。 前言:Webpack 与 gulp是目前圈子内比较活跃的前端构建工具。网上有很多二者比较的文章,面试中也会经常遇到gulp,Webpack的区别这样的问题。对于初学者来说,对这二...

    lwx12525 评论0 收藏0
  • gulp+webpack工作流探索

    摘要:概述最近研究了下工作流,先说一下我司的情况,我司现在是端用直出,用构建,部分就不进行描述了,因为网上的构建方法都是很成熟的了。 概述 最近研究了下工作流,先说一下我司的情况,我司现在是pc端用php直出,h5用vuejs构建,vuejs部分就不进行描述了,因为网上的构建方法都是很成熟的了。以下是php直出,需要向后台同学提供html文件的构建方法。调试都是在本地调试的,调试完成后打包生...

    fancyLuo 评论0 收藏0
  • gulp动化打包(上)

    摘要:自动化打包上文章概述本文分为上下两篇,上篇主要介绍一些常用的插件也是此次打包主要用的插件,而下篇主要以一个项目为例,从本地出合适的版本,压缩合并到最后打成包,发送至指定目录,做一个全面的演示。 gulp自动化打包(上) 文章概述 本文分为上下两篇,上篇主要介绍一些常用的gulp插件(也是此次打包主要用的gulp插件),而下篇主要以一个demo项目为例,从本地checkout出合适的g...

    roland_reed 评论0 收藏0
  • 基于 Gulp 的简易前端动化工程搭建

    摘要:生成的文件如下由于给文件添加了哈希值,所以每次编译出来的和都是不一样的,这会导致有很多冗余文件,所以我们可以每次在生成文件之前,先将原来的文件全部清空。中也有做这个工作的插件,因此我们可以在编译压缩添加哈希值之前先将原文将清空。 原文链接:http://mrzhang123.github.io/2016/09/07/gulpUse/项目链接:https://github.com/MrZ...

    Blackjun 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<