[文章]【木棉花】JS分布式能力——学习笔记

阅读量0
0
4
前言
JS也是具有分布式能力的,本文就以两个小项目来分享JS的分布式拉起和分布式迁移♪(∇*)
正文
这是从官网中找到的分布式API在FA生命周期中的位置图,图中的onStartContinuation()、onSaveData(OBJECT)、onRestoreData(OBJECT)和onCompleteContinuation(code)均为分布式能力接口
项目相同的操作:1. 安装和配置DevEco Studio 2.1 Release
DevEco Studio 2.1 Release下载、DevEco Studio 2.1 Release安装
2. 创建一个Empty Java Phone应用
DevEco Studio下载安装成功后,打开DevEco Studio,点击左上角的File,点击New,再选择New Project,选择Empty Ability(Java)选项,点击Next按钮。

分布式拉起将文件命名为Distributrd1,分布式迁移将文件命名为Distributrd2(文件名不能出现中文或者特殊字符,否则将无法成功创建项目文件),选择保存路径,选择API5,设备勾选Phonet,最后点击Finish按钮。
3. 准备工作
entry>src>main>config.json文件中最下方"launchType": "standard"的后面添加以下代码,这样就可以实现去掉应用上方的标签栏了。
config.json部分代码:
  1. "name": "com.test.distributed1.MainAbility",
  2.         "icon": "$media:icon",
  3.         "description": "$string:mainability_description",
  4.         "label": "$string:entry_MainAbility",
  5.         "type": "page",
  6.         "launchType": "standard",
  7.         "metaData": {
  8.           "customizeData": [
  9.             {
  10.               "name": "hwc-theme",
  11.               "value": "androidhwext:style/Theme.Emui.Light.NoTitleBar",
  12.               "extra": ""
  13.             }
  14.           ]
  15.         }
  16.       }
  17.     ],
  18.     "js": [
  19.       {
  20.         "pages": [
  21.           "pages/index/index"
  22.         ],
  23.         "name": "default",
  24.         "window": {
  25.           "designWidth": 720,
  26.           "autoDesignWidth": true
  27.         }
  28.       }
  29.     ]
  30.   }
  31. }
复制代码
4. 添加权限
config.json中添加权限。
  1.     "reqPermissions": [
  2.       {
  3.         "name": "ohos.permission.DISTRIBUTED_DATASYNC"
  4.       }
  5.     ],
复制代码
MainAbility.java中动态申请权限。
  1. public class MainAbility extends AceAbility {
  2.     @Override
  3.     public void onStart(Intent intent) {
  4.         super.onStart(intent);

  5.         // 动态判断权限
  6.         if (verifySelfPermission("ohos.permission.DISTRIBUTED_DATASYNC") != IBundleManager.PERMISSION_GRANTED) {
  7.             // 应用未被授予权限
  8.             if (canRequestPermission("ohos.permission.DISTRIBUTED_DATASYNC")) {
  9.                 // 是否可以申请弹框授权(首次申请或者用户未选择禁止且不再提示)
  10.                 requestPermissionsFromUser(new String[]{"ohos.permission.DISTRIBUTED_DATASYNC"}, 0);
  11.             }
  12.         }
  13.     }

  14.     @Override
  15.     public void onStop() {
  16.         super.onStop();
  17.     }
  18. }
复制代码
分布式拉起效果图
1. 实现界面布局
index.hml中编写以下代码。
添加两个button组件,类选择器名均为btn,分别添加一个单击事件,按钮上的文本分别为“加1”和“拉起”。
  1. <div class="container">
  2.     <text class="title">
  3.         {{ title }}
  4.     </text>
  5.     <button class="btn">加1</button>
  6.     <button class="btn">拉起</button>
  7. </div>
复制代码
index.css中编写以下代码。
添加类选择器btn,并修改其属性值。
  1. .container {
  2.     flex-direction: column;
  3.     justify-content: center;
  4.     align-items: center;
  5. }

  6. .title {
  7.     font-size: 40px;
  8.     color: #000000;
  9.     opacity: 0.9;
  10. }

  11. .btn {
  12.     height: 60px;
  13.     width: 100px;
  14.     font-size: 40px;
  15.     background-color: aquamarine;
  16.     margin: 10px;
  17. }
复制代码
2. 实现分布式拉起
index.js中编写以下代码。
分布式拉起允许拉起一个本地或远程的FA,拉起时可以传递参数。添加按钮点击事件distributed()通过FeatureAbility.startAbility(OBJECT)方法拉起一个FA,无回调结果,允许以显式的方式,拉起远程或本地的FA。
其中OBJECT为RequestParams类型的参数,包含必填的bundleName(要启动的包名。需和abilityName配合使用,区分大小写)、abilityName(要启动的ability名,区分大小写)和选填的entities(希望被调起的FA所归属的实体列表,如果不填,默认查找所有实体列表。需配合action使用)、action(在不指定包名及ability名的情况下,可以通过传入action值从而根据Operation的其他属性启动应用)、deviceType(默认0: 从本地以及远端设备中选择要启动的FA。1: 从本地设备启动FA。有多个FA满足条件的情况下,将弹框由用户选择设备)、data(指定要传递给对方的参数,需要可被序列化)、flag(拉起FA时的配置开关,如是否免安装等)、url(拉起FA时,指定打开的页面的url。默认直接打开首页)。
  1. export default {
  2.     data: {
  3.         title: "0"
  4.     },
  5.     onInit() {
  6.         
  7.     },
  8.     distributed(){
  9.         let target = {
  10.             bundleName: "com.test.distributed1",
  11.             abilityName: "com.test.distributed1.MainAbility"
  12.         };
  13.         let result = FeatureAbility.startAbility(target);
  14.     },
  15. }
复制代码
3. 实现带数据传递的分布式拉起
定义一个全局变量sum,并初始化为0。添加一个按钮点击事件plus()实现加1功能。
在FeatureAbility.startAbility(OBJECT)中添加一个参数data并实例化sum。
因为所有在data中设置的字段,在对端FA中均可以直接在 this下拿到,所以在生命周期事件onInit()中通过this.number取得该值。
  1. var sum = 0;

  2. export default {
  3.     data: {
  4.         title: "0"
  5.     },
  6.     onInit() {
  7.         sum = this.number;
  8.         this.title = sum;
  9.     },
  10.     distributed(){
  11.         let actionData = {
  12.             number: sum
  13.         };
  14.         let target = {
  15.             bundleName: "com.test.distributed1",
  16.             abilityName: "com.test.distributed1.MainAbility",
  17.             data: actionData
  18.         };
  19.         let result = FeatureAbility.startAbility(target);
  20.     },
  21.     plus(){
  22.         sum++;
  23.         this.title = sum;
  24.     }
  25. }
复制代码
分布式迁移效果图
1. 实现界面布局
创建一个名为Distributed2的Empty JS Phone空应用。

index.hml中编写以下代码。
添加两个button组件,类选择器名均为btn,分别添加一个单击事件,按钮上的文本分别为“加1”和“迁移”。
  1. <div class="container">
  2.     <text class="title">
  3.         {{ title }}
  4.     </text>
  5.     <button class="btn">加1</button>
  6.     <button class="btn">拉起</button>
  7. </div>
复制代码
index.css中编写以下代码。
添加类选择器btn,并修改其属性值。
  1. .container {
  2.     flex-direction: column;
  3.     justify-content: center;
  4.     align-items: center;
  5. }

  6. .title {
  7.     font-size: 40px;
  8.     color: #000000;
  9.     opacity: 0.9;
  10. }

  11. .btn {
  12.     height: 60px;
  13.     width: 100px;
  14.     font-size: 40px;
  15.     background-color: aquamarine;
  16.     margin: 10px;
  17. }
复制代码
2. 实现分布式迁移
index.js中编写以下代码。
分布式迁移提供了一个主动迁移接口及一系列页面生命周期回调,以支持将本地业务无缝迁移到指定设备中。添加按钮点击事件distributed()通过FeatureAbility.continueAbility()方法主动进行FA迁移的入口。
其中onStartContinuation()为FA发起迁移时的回调,在此回调中应用可以根据当前状态决定是否迁移。返回值为Boolean类型,true表示允许进行迁移,false表示不允许迁移。
onSaveData(OBJECT)为保存状态数据的回调,开发者需要往参数对象中填入需迁移到目标设备上的数据。参数为可被序列化的自定义数据。
onRestoreData(OBJECT)为恢复发起迁移时onSaveData方法保存的数据的回调,用于恢复应用状态的对象,其中的数据及结构由onSaveData决定。
onCompleteContinuation(code)为迁移完成的回调,在调用端被触发,表示应用迁移到目标设备上的结果。参数为迁移完成的结果。0:成功,-1:失败。
  1. export default {
  2.     data: {
  3.         title: "0"
  4.     },
  5.     onStartContinuation() { // 判断当前的状态是不是适合迁移
  6.         console.info("onStartContinuation被调用,适合迁移");
  7.         return true;
  8.     },

  9.     onCompleteContinuation(code) { // 迁移操作完成,code返回结果
  10.         if(code == 0){
  11.             console.info("onCompleteContinuation(code)被调用,迁移成功");
  12.         } else if(code == -1){
  13.             console.info("onCompleteContinuation(code)被调用,迁移失败");
  14.         }
  15.     },
  16.     onSaveData(saveData) { // 数据保存到savedData中进行迁移。
  17.         console.info("onSaveData(saveData)被调用");
  18.     },
  19.     onRestoreData(restoreData) { // 收到迁移数据,恢复。
  20.         console.info("onRestoreData(restoreData)被调用");
  21.     },
  22.     distributed(){
  23.         let result =  FeatureAbility.continueAbility();
  24.     }
  25. }
复制代码
3. 实现带数据传递的分布式迁移
定义一个序列化continueAbilityData,其中的number为0。添加一个按钮点击事件plus()实现加1功能。
在onSaveData(saveData)函数中将序列化continueAbilityData保存到savedData中进行迁移。在onRestoreData(restoreData)函数中将迁移的数据显示出来。
  1. export default {
  2.     data: {
  3.         title: "0",
  4.         continueAbilityData: {
  5.             number: 0
  6.         }
  7.     },
  8.     onStartContinuation() { // 判断当前的状态是不是适合迁移
  9.         console.info("onStartContinuation被调用,适合迁移");
  10.         return true;
  11.     },

  12.     onCompleteContinuation(code) { // 迁移操作完成,code返回结果
  13.         if(code == 0){
  14.             console.info("onCompleteContinuation(code)被调用,迁移成功");
  15.         } else if(code == -1){
  16.             console.info("onCompleteContinuation(code)被调用,迁移失败");
  17.         }
  18.     },
  19.     onSaveData(saveData) { // 数据保存到savedData中进行迁移。
  20.         var data = this.continueAbilityData;
  21.         Object.assign(saveData, data)
  22.         console.info("onSaveData(saveData)被调用");
  23.     },
  24.     onRestoreData(restoreData) { // 收到迁移数据,恢复。
  25.         this.continueAbilityData = restoreData;
  26.         this.title = this.continueAbilityData.number;
  27.         console.info("onRestoreData(restoreData)被调用");
  28.     },
  29.     distributed(){
  30.         let result =  FeatureAbility.continueAbility();
  31.     },
  32.     plus(){
  33.         this.continueAbilityData.number++;
  34.         this.title = this.continueAbilityData.number;
  35.     }
  36. }
复制代码
写在最后
更多资料请关注我们的项目: Awesome-Harmony_木棉花
本项目会长期更新 ,希望随着鸿蒙一同成长变强的既有我们,也有正在看着这个项目的你。明年3月,深大校园内的木棉花会盛开,那时,鸿蒙也会变的更好,愿这花开,有你我的一份。

回帖

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容图片侵权或者其他问题,请联系本站作侵删。 侵权投诉
链接复制成功,分享给好友