ionic3 项目热更新使用

配置热更新

热更新的原理:

这一步我就不上图了,服务器上的chcp.manifest文件对比本地生成的chcp.manifest中的hash值,如果hash值对应的文件发生更改,通过chcp.json中设置的文件存放地址,进行文件流的下载更新。

安装热更新cli

  • npm install -g cordova-hot-code-push-cli

安装热更新插件
ionic cordova plugin add cordova-hot-code-push-plugin

开发使用可以安装配套插件
cordova plugin add cordova-hot-code-push-local-dev-addon

使用热更新

*插件安装完毕,在www目录下面,会生成两个文件,chcp.json文件,跟chcp.manifest文件。当你运行corodva-hcp server的时候,你每更改一个文件,chcp.manifest跟chcp.json就会发生相应的更改。
*但是生成的地址会变成一个临时的镜像地址,所以需要添加一个cordova-hcp.json 文件模板。这时候不需要启动cordova-hcp server,直接启动cordova-hcp build
cordova-hcp.json文件内容大致如下

"content_url": "http://yourserverAddress/www", //远程地址www后面不要加上/
"update": "now"//分三种情况
// start - app启动时安装更新. 默认值.
// resume - app从后台切换过来的时候安装更新.
// now - web内容下载完毕即安装更新.
 "release": "2017.07.01-15.52.14",  //版本号
 "min_native_interface": 1 //min_native_interface:版本设置。
 在config.xml我们设置的native-interface version=5 那么我们生成的就会是 
 "min_native_interface":5

  • 插件安装完毕,需要在config.xml文件里面添加
<chcp>
  <native-interface version="1" />
  <config-file url=".../chcp.json" />
<chcp/>
...为你的服务器地址。

定义当前版本:

<chcp>
    <native-interface version="5" />
</chcp>

如果你应用程序的版本比服务器的版本还高,那么插件将不会从服务器加载新的更新,默认设置为1。

自动下载:

<chcp>
  <auto-download enabled="false" />
</chcp>

定义插件是否允许下载更新。最初更新提取是自动执行的,可以禁用它,并通过JavaScript模块手动执行。默认情况下,首选项设置为true。

自动安装:

<chcp>
  <auto-install enabled="false" />
</chcp>

定义插件是否允许安装更新。最初更新安装是自动执行的,可以禁用它,并通过JavaScript模块手动执行。默认情况下,首选项设置为true。

  • 如果你的服务器,无法接受跨域访问的话,热更新插件很可能会不成功,所以可以更改服务器的配置,使其接受跨域下的访问,插件才能从服务器上把文件给下载下来。

简单的说明

可用事件
chcp_updateIsReadyToInstall - web内容已经下载并可以安装时触发.
chcp_updateLoadFailed - 插件无法下载web更新时触发. 详细错误信息在事件参数里.
chcp_nothingToUpdate - 无可用更新下载时触发.
chcp_updateInstalled - web内容安装成功时触发.
chcp_updateInstallFailed - web内容安装失败时触发. 详细错误信息在事件参数里.
chcp_nothingToInstall -无可用更新安装时触发.
chcp_assetsInstalledOnExternalStorage - 插件成功把app内置的web内容拷贝到外置存储中时触发. 你可能需要开发调试时用到这个事件,也许不会.
chcp_assetsInstallationError -插件无法拷贝app内置的web内容到外置存储中时触发. 如果此事件发生了 - 插件不再工作. 也许是设备没有足够的存储空间导致. 详细错误信息在事件参数里.

在需要使用热更新的文件中声明
declear  var chcp:any //防止程序提示找不到chcp

更加详细的说明跟使用可以参考
http://blog.csdn.net/lovelyelfpop/article/details/50848524
或者
http://www.jianshu.com/p/9e3cd54f5f97

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,269评论 19 139
  • 热更新:当用户初次打开app,它会将所有的web内容复制一份到外部存储。此后从外部存储加载web内容,而并不加载打...
    方千竹阅读 1,804评论 0 0
  • 简介 关于Cordova的热更新问题,国内的资料比较少,许多博客上都是胡乱的抄袭,准确性极低,无任何实用性,并且步...
    cl9000阅读 6,427评论 10 15
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 47,005评论 6 342
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,635评论 25 709