前端团队 Gulp & Webpack 工作流 迁移记

折腾

从 2015 到现在,短短的三年内,几乎每年折腾一下工作流的 “ 更新换代 ”。从最早开始使用 Grunt 到 Gulp 再到 Webpack,再到 Rollup,再到 Webpack@2.x ......

在这个前端工具变化如此之快的浪潮里,在前端团队中,并发合作开发多个项目,前后端分离等等情况下,配置 或者 升级 或者 迁移 这样的工作流 基本生产工具,往往造成耗费的就不是仅仅一个人的时间成本,而是十人,数十人的量级。

所以 一个靠谱、稳定、有效的工作流方案就显得特别重要。

Gulp

14 年 15 年初,因为构建性能等问题,已经从 Grunt 迁移到 Gulp 了 ( duowan/generator-lego )。从开源的 Github 仓库上不难看出,主要 工作流 是基于命令行的形式,配合 yeoman 脚手架工具,以 Gulp 任务为核心的。

对于 Gulp 定义,官方的说法是

gulp is a toolkit for automating painful or time-consuming tasks in your development workflow, so you can stop messing around and build something.

表明着,Gulp 是一个专门帮你处理一些痛苦耗时的自动化任务工具。

在这个表述中,Gulp 倾向的是于对 “任务” 这个概念的处理,而这个 “任务”,其实如果我们都尝试配置过 Gulp 的话,也就大概明白是怎样的一回事。

在这段时间期间,团队面向的业务,主要分类占比最大的是 专题类,运营类。

在这类专题基本入口都是从 HTML 开始,写 HTML Dom 结构,写样式,再后可能就写一些 JS 动效或者 AJAX 。几乎 JS 占比分量是超级少的,个别页甚至没有脚本,单纯给到 HTML & CSS 给到后端同事直出数据。

那时候 Gulp 所配置的任务

  • 监听匹配文件的变化自动刷新浏览器
  • 自动编译 SASS
  • 自动补全 CSS3 前缀
  • 多雪碧图合并、2x、3x 拼图
  • 等等

基于编译 HTML / SASS / 图片的任务,已经是完全满足我们的需求了。

Webpack

在 15 年末开始,渐渐接入的业务方向改变,需要接触到 Vue,也就渐渐发现 Gulp 对于 JS 模块处理的局限性。也在这时候,开始衡量是否需要迁移到 Webpack。

对于 Webpack 定义,官方的说法是

webpack, the production / unbiased / flexible / extensible / open source module bundler.

表明着,Webpack 是一个 xxx 的打包器。

而在这个表述中,Webpack 更多的偏向于资源的整理打包。而这个打包的开始,就是 定义在配置上的 entry。

对于 Vue 或 React 这类型的项目,Webpack 无疑是最最最适合不过了,以 JS 模块为编写入口,生成依赖链,整理打包出 HTML / JS / CSS / 图片。

开始本来也就以为 单单工作流核心 将 Gulp 迁移到 Webpack,这样就可以轻松解决。

直至到后来在 雪碧图的合并,2x / 3x 多倍图的输出上,在 Webpack 上苦苦找寻不了比较完美的解决方案等等。

另外团队还存有一些 专题业务类 的需求,也需要兼容旧有项目,团队成员开发时候,切换前端生产工具的适应性等,带来了一系列的问题。

这时迫切希望有 更加简便、有效的工作流方案。

Gulp + Webpack

既然 Gulp 对任务处理的强大,而 Webpack 对 JS 模块处理的专业,也就衡量着这两者的混合。

由 Gulp 基于处理 HTML / SASS / 图片等部分,Webpack 主要对 JS 模块进行编译。
带着这样的想法,也有网上挺多的思路,例如 gulp + webpack 构建多页面前端项目

但是都忽略了较根本上的问题 :

  • 每次 JS 改变都重新通过 Webpack 完整打包输出,效率没有保证
  • Webpack 下 JS 热刷新应该怎么联动 Gulp 的热刷新

基于解决根本痛点的,平衡功能,使用了另外一套方案 :

  1. Webpack 基于 webpack-dev-server 启动热刷新 服务 A
  2. browser-sync 使用 proxy 代理 服务 A 启动 服务 B
  3. Gulp watch HTML / SASS / 图片 变动
  4. Gulp watch 变动后触发 browser-sync reload
  • 通过 webpack-dev-server 热刷新等方式,优化 开发中 JS 构建效率
  • 通过 proxy 代理 让 webpack-dev-server 热刷新同步刷新 浏览器

Gulp 负责部分的 HTML / SASS / 图片等任务基本没有太大的变动,因而可以兼容到过往的旧项目需求,另外团队成员额外需要了解的是 JS 模块 Webpack 部分的构建,学习成本相对降低,在 2015 年末正式作为工作流解决方案加入在团队脚手架工具。

走多一步

2016 年初开始,因组内成员的增加,或者工作流功能版本的更新, 都伴随着维护工作流的各种问题 ( 即便写了不能再详细的文档 ),大致回归到 Node 版本的兼容性,node_modules 的版本功能兼容,Windows / macOS 带来的兼容性等等问题。
这时在思考着,能否有包装多一层去让这些兼容性问题都 避免开呢 ?

其实对于这样的整体封装,无疑有两条路可以走

  • 类似于 NW 那样构建出 平台应用
  • 类似于 PKG 那样构建出 执行程序

在寻找解决方案的时候,发现了 weixin/WeFlow ,但深入发现 WeFlow 仅基于 Gulp 任务,功能远远满足不了需求。

于是便开始了轮子的重构,首先遇到问题是 node-sass 的编译依赖问题,感谢 WeFlow 开发者分享踩过的坑( node-sass 依赖环境问题 · Issue ),如果团队是使用 less 或者 stylus 都无需重置那些依赖。

另外遇到了最麻烦的问题就是把 webpack 生态 迁移到应用上去,babel 依赖 / vue-loader 依赖 / ..... 其中遇到过各种依赖被重置到全局的问题,都在 babel 或者 vue-loader 的源码上进行 切面置换依赖。

经过几个内测版本的开发下,造出了 legoflow/legoflow

组内推行使用后也得到了 赞同的反馈,经过了几个大项目的洗礼后,从功能性变得更加丰富,兼容性上更加稳定。

而在今年 6 月也对外兼容版本 LegoFlow

走得更远

现在工作流中内置的 Webpack 还是基于 1.x 版本,其实在年初的时候是有想法把 整个 Webpack 生态升级为 2.x,因为在 webpack 2.x RC 期间,对 Rollup tree-shaking 已经很垂涎了。

但是 Webpack 正式到 2.x,却发现无法兼容到 IE8 ( webpack2 doesn't support IE8 · Issue #3070 · webpack/webpack ),部分业务也脱离不了 IE8 的行列。

但计划在更远一点的时间下,看看如何能否到实现 Webpack 1.x & 2.x 的无缝切换。

最后

前端团队几次的生产力工作流工具的迁移,只是前端这个大浪潮中最小最小的 缩影。

每次改变像是意味着 进化,在如今 这个前端浮躁的年代,希望 做着相同事情的我们 有着一如既往的 初心 上下求索。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容