/wepack

:four_leaf_clover: 小程序构建工具 ♂ 重新实现小程序子集

Primary LanguageJavaScriptMIT LicenseMIT

fre logo

npm init wepack

wepack 还比较稚嫩,但无论如何我想将它开源出来,一方面是为了“公开工作”,另一方面我需要大家的帮助,将它变得更稳定

wepack 是一个小程序打包工具,它负责将标准的微信小程序打包成 web 项目,这样做有很多好处——

  • 小程序引擎 - 将打包产物跑到 APP webview 上,就可以成为专属小程序,如“携程小程序”
  • 开箱即用 - 更现代的标准,更短的开发链路,从某种程度上缓解微信小程序的历史包袱
  • 跨双端 - 以保住微信为前提,一套代码,支持微信和 h5 两个端

wepack 借助 fre 实现组件化的支持,借助 berial 实现路由和沙箱,不借助 webpack 等打包工具

除了基本的编译打包,wepack 实现了一些先进特性:Tree shakingModule federationHot reload,做更现代,更简洁的小程序子集

Use

npm init wepack

npm start

剩下的只需要按照 微信小程序开发文档 开发即可

值得注意的是,并非所有的微信小程序的特性都被支持,简单地说,wepack 只支持“现代特性”

Motivation

在 wepack 之前,大量小程序工具使用 webpack 进行打包,各种 loader、plugin 导致整个开发链路变长

wepack 旨在解决链路问题,它自研编译器和打包器,对于标准小程序项目,可以做到开箱即用

Package

Package Description Version
@wepack/core 微信小程序打包器 npm
@wepack/wxml wxml 编译器 npm

Design

wepack

License

MIT @ctripcorp