注意:本工程为脚手架内置的用于转换小程序代码的工具,生成的代码只能放置在客户端内运行,如果想让生成的代码在浏览器中运行,请使用weweb
# 安装
npm i -g hera-weweb
# 打包小程序
## 请注意,请勿在小程序所在目录下使用
## 以防生成的文件与小程序代码混在一起
hweweb projectDir -d distDir
# 查看生成的文件
ls distDir
# 运行
## 将生成的文件放置在客户端代码中
## Android:AndroidDemo/src/main/assets/demoapp.zip
## iOS:iOSDemo/demoapp.zip
# 安装依赖
npm i
# 开发framework
npm run dev
# build framework
npm run build
# 打包framework (打包之前先build)
./bin/weweb -b
# 打包demo
./bin/weweb ./demo
- h5
- ├── bin //weweb命令行入口文件
- ├── demo //小程序demo
- ├── dist //weweb编译时默认输出目录
- ├── docs //文档目录
- ├── lib //weweb命令行依赖库
- ├── src //框架源码
- └── tmp //框架源码build后输出目录
- src
- ├── common //service层与view层公共模块目录,包括jsbridge与reporter模块
- ├── css //通用样式文件
- ├── service //service层核心库相关模块目录
- ├── template //框架模板相关文件目录
- └── view //view层核心库相关模块目录
- 检测app.json文件是否存在
- 清空并创建指定的输出目录
- 根据service.html模板,带上版本信息输出到指定的目录中
- 读取配置文件app.json,将其注入到service-config.js中,输出到指定的目录中
- 读取所有小程序代码中所有的JS文件,同时判断其是否在app.json中定义,如果其没被定义也不是app.js,说明其为引入的module, 将这些JS路径名存入一个数组中,并确保app.js和页面文件放置在数组尾部
- 遍历JS文件数组并读取它们,根据用户设置项判断是否使用Babel将其转换为es5的代码
- 把js模块封装成CommonJS模块,并合并成app-service.js这个文件输出
- 根据app.json里的pages配置,遍历每个页面根据页面wxml,wxss生成相应的页面文件
- 小程序根目录(如:demo目录)增加heraConf.js文件,配置示例如下:
module.exports = {
extApi:[
{//普通交互API
name: 'openLink',//扩展api名 该api必须Native方实现了
params: { //扩展api 的参数格式,可以只列必须的属性
url: ''
}
}
]
}
# 打包framework (打包之前先build)
./bin/weweb -b
# 运行
# 打包demo
./bin/weweb ./demo
- 执行命令后会生成zip包,将framework或小程序文件打包,提供给Android及iOS端
小程序转h5 weweb的命令实现前期参考了wept项目的实现,目前有部分代码也是沿用了wept的或在这基础上改造而来。在此,特别感谢wept的作者 chemzqm 的无私奉献
如果你有好的意见或建议,欢迎给我们提 issue 或 PR,为优化 hera 贡献力量