写点什么

大规模的前端组件化与模块化

  • 2014-04-26
  • 本文字数:2392 字

    阅读完需:约 8 分钟

本文根据 Andrew Betts 在 QCon 北京 2014 大会上的主题演讲内容整理而成。

Andrew Betts 是英国金融时报实验室(FT Labs)的负责人,同时也是一位 PHP 和 JavaScript 程序员。他的团队致力于研发试验性质的 Web 技术并发布相关产品——比如金融时报 Web App. 在加入金融时报实验室之前,Andrew 创建了 Web 咨询公司 Assanka,为诸如 News International, The Economist Group and the FT 这样的客户打造创新性的 Web 项目。

今天的话题是大规模的前端组件化与模块化。首先,先介绍一下 FT 在研发方面面临的挑战:

不同的服务如搜索、内容、广告、应用,都是由不同的团队来开发,团队之间的沟通较少。造成的结果就是,整个服务的灵活性和可维护性越来越差,系统变得越来越复杂之后,新人进来的学习难度很大。随着整个软件开发生命周期变得越来越复杂,新功能的集成变得越来越难;更糟糕的是,随着移动设备的流行,研发团队不得不把同样一套逻辑分别在桌面端和移动端各自实现一次。这也是全世界的软件研发团队面对的挑战。

为了应对这些问题,FT Labs 开始推行几条前端的开发理念,目前已经获得比较好的效果。

第一条理念是:“活的”风格指南。“活的”风格指南也可以理解为代码即文档,文档即示例。这里举一个例子,比如 Facebook 的 React 项目。你去看 React 项目的介绍页,这个页面本身就是一个 React 的推荐实现。

当然像 React 这样的项目,说明页面的实现是一个方面,此外还有另一个重点:组件化的开发方式。正如 React 不是一个框架——它提倡的是无框架,因为任何框架的引入都会增加额外的复杂度和学习成本。组件(Web components)则不同,它一旦开发出来,就是一个随时可以很方便的调用的功能;而且,不同的团队可以同时进行不同组件的开发而互不干扰。Web 组件是一个正在快速发展中的特性,目前浏览器对它的支持还不完美,不过也就是 1-2 年的时间,现在应该要为未来做准备。对于 Web 开发而言,向前兼容要比向后兼容更加重要。

组件化的使用在我们处理历史网站的过程中节省了大量的工作。FT 有超过 600 个域名需要维护,很多网页从互联网时代早期就开始运作。对于这些遗留页面,要全都重写以适应新的浏览器是代价高昂、不值得的,但你又要尽可能的让它们能够正常显示。我们用组件来进行局部替换以解决这个问题。比如某个老页面上有一个图库展示,现在的浏览器不能显示了,你就批量把这种老旧的图库展示代码替换成新的图库组件代码即可。

另外还有一点很重要,就是拥抱模块化,避免在代码中嵌入依赖关系。做开发这行儿一个很重要的觉悟就是:你要相信,你现在写出来的这些代码,等两年之后,你自己都会不想去看它。模块化会让你的生命更简单。

对于浏览器兼容性,正如刚才所说,我们的建议是跟着最新的浏览器功能走。不过这里面也有一个分界点,就是所谓 core experience 和 primary experience 的分界点,并尽可能的将分界点向扩大 core experience 的方向推进。对于 NoJavaScript 的处理,我们的经验是,基本上所有人的浏览器都会支持 JS 的,尽可以放心大胆的用。

说到这里,我要进入今天的重头了,那就是 FT 的 Origami 这个项目。Origami 这个项目要做定义的话可以说是一套规范,是一组文档化的最佳实践,同时搭配 Registry 这套工具,以方便所有人以最佳实践建立规范统一的服务和组件。

这套系统的构成大体上包括一套 closure compiler,browserfy(+debowerfy&brfs),commonjs,sass(用于做 css 模块化),taskrunner(基于 grunt),以及 bower。系统在设计上遵循几个原则:

  • 编译时纳入所有依赖
  • 去中心化、分布式,比如我们的 git repo 是分散的,没有一个所谓的 core 或 common 的 codebase
  • 内置命名和封装的规则

对于上面提到的分界点,Origami 是这样处理的:core 的部分需要保证在用户环境对 JavaScript 支持差或不支持的情况仍然能够完成基本内容的呈现、搜索引擎的抓取等。这个分界点在 Origami 当中通过 if (querySelector in document) 来实现判定。

Registry 作为工具,会做以下几个事情:

  • 扫描所有已知的 git 服务器
  • 给版本标签建索引
  • 给每个模块的每个版本做 build
  • 把每个模块的所有版本收集、整理到一个模块页面上

Registry 可以说是我们 Web 服务的一个黄页。我们把这个黄页放在公开的互联网上,这样所有人都可以上去协作,每个人都可以查看每个组件的每个版本,它们的说明和相关文档,实现的样板等。如果有的功能还没做完或者没启用,可以打上一个 not implemented 的 flag。

大家可以在 Registry 上随意查看我们的各个组件,比如 header,footer,调色板,按钮等。这些组件调用起来很简单,以调色板为例,只需要

复制代码
<link rel="stylesheet" href="http://build.origami.ft.com/bundles/css?modules=o-colors@^2.3.8" />
<script src="http://build.origami.ft.com/bundles/js?modules=o-colors@^2.3.8"'></script>

这样的两行代码即可调用任意模块的任意版本。

我们的 build 服务可以按需 build 不同模块的任意组合,之后还进行打包、压缩、优化等处理并通过 CDN 分发(经过了 GZIP 处理)。调用的时候可以指定调用指定的版本,或者自动调用最新版。有了这套系统后,开发者创建原型变得非常简单了。

下面我介绍一下我们遇到的一些零碎问题,以及我们是如何处理的。

首先,有关 polyfill 的加载,如何才能让 polyfill 仅在需要的时候才加载?我们的处理办法是在模块的 metadata 中进行声明,哪些是 required,哪些是 optional,以 modernizr 测试名来进行控制。

然后,如何在支持 JS 但是支持的不好的浏览器中显示 noscript 当中的内容?我们的办法是定义一个 o-nojs-fallback 类的 div,通过类的 visibility 来控制呈现。

对于 hover 的处理,我们用了一个 o-hoverable 的组件来控制。

对于资源加载,为了确保每个组件都知道其他资源的 URL 地址,我们专门有一个 o-asset 组件

最后想说的是,将我们的这些工作公开在互联网上,我们从中收获了很多。

2014-04-26 20:328469

评论

发布
暂无评论
发现更多内容

技术人的2023年总结:以梦为马,不负年华

言程序

大模型 AIGC 2023年技术盘点

大数据安全与隐私保护:构建可信的数据生态系统

范艺笙冉

1688店铺详情数据接口(1688.seller_info)丨1688API接口

tbapi

1688API接口 1688店铺详情接口 1688公司详情接口 1688店铺评分接口

按图搜索1688商品(拍立淘)接口(1688.item_search_img) 丨1688图片搜索API接口

tbapi

1688图片搜索接口 按图搜索1688商品数据接口 1688图片搜索商品接口 1688拍立淘接口 1688图片搜索API接口

2023年度总结之大模型的微调

木子李

#技术人的2023总结

无表情包不MEME,PADD 最具潜力的BRC20 meme

股市老人

我的2023技术总结:以梦为马,不负年华

言程序

大模型 #技术人的2023总结

结束不是终点,而是新的起点

晴空万里

技术人的 2023 总结之无处不在的AI

六月的雨在InfoQ

AI 2023 #技术人的2023总结

【新手入门】如何java来求各种数

极客罗杰

Java中的秘会厅ThreadLocal你了解吗?

架构虫哥

Java 并发编程 ThreadLocal java 并发 Java并发编程

云原生技术的探索与实践| 主赛道

Emo_TT

云原生 年终总结

KubeWharf: 云原生分布式操作系统体验部署

RoSofteg

KubeWharf

2023年总结:不上班的这半年!

王磊

代码人生

癸卯年之大模型经验总结

穆雄雄

AI大模型 大模型时代 雄雄的小课堂

paypal实操常见问题——绑卡篇

跨境

PayPal

「亲测有效」ChatGPT Plus会员/GPT4开通方法 — 仅需支付宝或微信

跨境

openai VISA ChatGPT

E3PO:360°视频模拟的探索与发现

RoSofteg

E3PO

2023 年大模型技术基础架构盘点与开源工作速览

中杯可乐多加冰

大数据技术年度总结 | 主赛道

Emo_TT

大数据 可视化 年终总结

在iOS应用中使用实时活动与灵动岛

珲少

探索云原生化的服务架构体系的技术风向,攻克云原生化微服务架构的痛点和特性

码界西柚

微服务架构 云原生架构 #技术人的2023总结 火山引擎开发者社区

一次不算太好的 E3PO 项目体验

战场小包

开源 视频流 E3PO

打造新一代云原生"消息、事件、流"统一消息引擎的融合处理平台

码界西柚

RocketMQ 云原生 #技术人的2023总结 火山引擎开发者社区 2023年技术盘点

强大的高效视频处理框架——BMF

白日梦

视频处理 多媒体 BMF

ChatGPT使用注意事项有哪些?

跨境

openai VISA ChatGPT

大模型:未来的智能方向

在书中成长

AI 大模型 ChatGPT

技术人的2023漫谈AI语音体验之路

RoSofteg

#技术人的2023总结

2023-12-30:用go语言,给你一个下标从 0 开始的整数数组 nums ,它包含 n 个 互不相同 的正整数, 如果 nums 的一个排列满足以下条件,我们称它是一个特别的排列。 对于 0 <

福大大架构师每日一题

福大大架构师每日一题

大规模的前端组件化与模块化_QCon_sai_InfoQ精选文章