react-native-webpackager-server
v1.0.2
Published
react native webpackager server
Downloads
2
Readme
react-native-webpackager-server
该插件主要意图在做lib和app业务代码的分离;react-native-webpack-server里基本上已经实现了一套代码分离服务;在该插件基础上优化了一些东西,感谢该作者哈~
react-native-webpack-server分离
react-native-webpack-server分离启动了三个服务
- 8081是原来RN服务,用来打包RN的lib代码
- 8082是webpack-dev-server,用来打包app的业务代码
- 8080 是新建的server服务,生成webpack的external输出8081和8082的合并结果
但是发现作者打包的过程和RN的过程一样,启动非常慢,做了几点改进,
安装
npm install --save-dev react-native-webpackager-server
使用
具体用法,可参考demo里用法,
也可以用react-native-webpack-server原来的用法,
demo的用法我自己写个8080的router,在执行 npm run start
时传入了 自定义ruoter的方法
demo里的示例放在./router文件夹里,供8080的server调用,传入的参数可自己查看代码进行定制
获取所有代码的 地址为http://localhost:8080/all.code?platform=ios&dev=false&minify=true
获取RN的lib的 地址为http://localhost:8080/lib.code?platform=ios&dev=false&minify=true
获取业务代码的 地址为http://localhost:8080/app.code?platform=ios&dev=false&minify=true
优化体现在以下两方面
1 start服务时,不是动态生成externals,而是只生成一次
优化webpack打包生成externals的方法,只在第一次生成时按照RN版本+是否是dev生成对应的externals文件,下次 根据请求的RN版本+dev参数的文件,因为只有这两个参数会影响externals
2 将用于生成lib的写法固定到具体文件里,分为ios和android
3 缓存lib库
在调试的时候,任何变动都会引起RN打包(这里没有仔细看是否制定projectRoot参数是否会起作用), 但是实际上RN的lib文件变动只和platform、dev和minify三个参数有关,按照这三个参数进行缓存,加快输出速度
4 webpack的minify通过引入uglify-js根据参数来输出
5 引入手动制定server的routes
具体用法和 react-native-webpackager-server 一样 启动的时候加入routerServer的地址, 具体可见router文件,里面有三个路由可以生成lib、app以及所有代码的输出
6 webpack的demo 见webpack.config.js.demo
其中 1 2 3都可以大大提高启动和调试时获取bundle的速度,尤其是缓存了当前rn版本对应的lib库后;
5引入自定义的router之后 ,可以很灵活的结合自己业务进行lib库和app本身的逻辑代码,发布app时,把bundle拆分为lib和app代码, 可以减少bundle下行下载的速度,不用下载rn的lib库
后续优化
1 对分离的lib代码和app代码,提供一个服务进行单独的版本管理,目前可想到的根据端类型(ios或android)+端版本+RN版本+业务代码进行更新
2 热更新机制,这个还没仔细研究RN是怎么实现的,看能不能webpack也实现下,原来的 react-native-webpack-server是没有实现