使用web-component搭建企业级组件库

组件库的现状

前端目前比较主流的框架有react,vuejs,angular等。

我们通常去搭建组件库的时候都是基于某一种框架去搭建,
比如ant-design是基于react搭建的UI组件库,而elementUI则是基于vuejs搭建的组件库。

虽然目前社区有相关工具,提供框架之间的转化服务,比如讲vuejs组件转化为react组件。
但是毕竟是不同的框架,有不同的标准。因此框架api发生变动,那么你就需要重写转化逻辑,
显然是不灵活的,因此我们暂不讨论这种情况。

作为公司而言,就需要为不同的框架写不同的组件库,尽管逻辑都是一样的。

另外如果框架升级,比如从1.x升级到2.x,那么对应组件库就需要升级,如果公司的组件库有很多(vuejs,react,angular等),
那么这种升级的概率就会更大。

什么是web-component?

那么有没有更好的方案,一次编写,到处使用呢?

答案就是借助web component。

Web Components 是一系列加入w3c的HTML和DOM的特性,使得开发者可以创建可复用的组件。

由于web components是由w3c组织去推动的,因此它很有可能在不久的将来成为浏览器的一个标配。

Web Components 主要由以下四个部分组成:

  • Custom Elements – 定义新html元素的api
  • Shadow DOM – Encapsulated DOM and styling, with composition
  • HTML Imports – Declarative methods of importing HTML documents into other documents
  • HTML Templates – The