经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
用CodePush在React Native App中做热更新
来源:cnblogs  作者:真-张三疯  时间:2019/10/8 9:23:08  对本文有异议

最近在学React Native,学到了CodePush热更新。

老师讲了两种实现的方法,现将其记录一下。

相比较原生开发,使用React Native开发App不仅能节约开发成本,还能做原生开发不能实现的热更新功能。

使用原生技术开发App时,每次代码做了改动后,都需要提交到应用商店进行审核,审核通过后,需要等用户重新下载安装后才会生效。而如果使用React Native开发App,开发者可随时发布新版本,不用经过应用商店的审核,用户即可使用到新版本,并且还可做到不用经过用户的同意就强制安装新版本。

CodePush是微软的技术,因为服务器在国外,所以不太稳定。如果开发的App是针对国内市场的,应该使用CodePush中国

要使用CodePush,需安装cpcn-react-native依赖包。可使用官方提供的工具cpcn-client来安装依赖包。cpcn-client的下载地址是:http://code-push.cn/docs/1010.htm 。

代码实现比较简单。第一种方法是直接改变App.js组件:

  1. import cpcn from 'cpcn-react-native';
  2. class App extends Component {
  3. }
  4. App = cpcn(App);
  5. export default App;

这种方法在有新版本更新时,会使用默认的提示框,提示框中的文字也是默认的。灵活性不够。

第二种方法比较灵活,可以自定义对话框和进度条。这种方法使用 cpcn.check() 方法。

  1. import cpcn from "cpcn-react-native";
  2. class App extends Component {
  3. componentDidMount(){
  4. cpcn.check({
  5. checkCallback: (remotePackage, agreeContinueFun) => {
  6. if(remotePackage){
  7. }
  8. },
  9. downloadProgressCallback: (downloadProgress) => {
  10. },
  11. installedCallback: (restartFun) => {
  12. }
  13. });
  14. }
  15. }
  16. export default App;

将 cpcn.check() 方法写在 App.js 的 componentDidMount 方法内,当 App 组件加载后调用此依法。

cpcn.chedk() 方法的参数:

checkCallback: 在检查是否有可更新的版本后调用这个方法,如果 remotePackage 不是 null,表示有可更新的版本。如果要继续更新,就调用 agreeContinueFun(true),如果不想继续更新,就调用 agreeContinueFun(false)。

downloadProgressCallback: 在下载新版本的过程中调用这个方法。可用它的参数 downloadProgress 做进度条。downloadProgress.receivedBytes 是已经下载的字节数,downloadProgress.totalBytes 是总字节数。

installedCallback: 当新版本安装完成后调用这个方法。需调用 restartFun(true) 重启App,重启后新版本就生效了。

原文链接:http://www.cnblogs.com/mafengzi/p/11632498.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号