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文件里面添加

  
  

...为你的服务器地址。

定义当前版本:


    

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

自动下载:


  

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

自动安装:


  

定义插件是否允许安装更新。最初更新安装是自动执行的,可以禁用它,并通过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

你可能感兴趣的:(ionic3 项目热更新使用)