未验证 提交 dcd5f7c6 编写于 作者: O openharmony_ci 提交者: Gitee

!9791 【data_object】分布式数据对象开发指导 文档优化修改

Merge pull request !9791 from wangxiyue/master
...@@ -93,84 +93,78 @@ ...@@ -93,84 +93,78 @@
``` ```
2. 请求权限。 2. 请求权限。
需要在`config.json`文件里进行配置请求权限(FA模型),示例代码如下: 需要在`config.json`文件里进行配置请求权限(FA模型)
```json ```json
{ {
"module": { "module": {
"reqPermissions": [ "reqPermissions": [
{ {
"name": "ohos.permission.DISTRIBUTED_DATASYNC" "name": "ohos.permission.DISTRIBUTED_DATASYNC"
} }
] ]
} }
} }
``` ```
Stage模型下的权限请求请参见[权限声明-Stage模型](../security/accesstoken-guidelines.md#stage模型) Stage模型下的权限请求请参见[权限声明-Stage模型](../security/accesstoken-guidelines.md#stage模型)
这个权限还需要在应用首次启动的时候弹窗获取用户授权,可以通过如下代码实现: 这个权限还需要在应用首次启动的时候弹窗获取用户授权
```js ```js
import featureAbility from '@ohos.ability.featureAbility'; import featureAbility from '@ohos.ability.featureAbility';
function grantPermission() { function grantPermission() {
console.info('grantPermission'); console.info('grantPermission');
let context = featureAbility.getContext(); let context = featureAbility.getContext();
context.requestPermissionsFromUser(['ohos.permission.DISTRIBUTED_DATASYNC'], 666, function (result) { context.requestPermissionsFromUser(['ohos.permission.DISTRIBUTED_DATASYNC'], 666, function (result) {
console.info(`result.requestCode=${result.requestCode}`) console.info(`result.requestCode=${result.requestCode}`)
}) })
console.info('end grantPermission'); console.info('end grantPermission');
} }
grantPermission(); grantPermission();
``` ```
3. 获取分布式数据对象实例。 3. 获取分布式数据对象实例。
以下为创建分布式数据对象的代码示例:
```js ```js
var local_object = distributedObject.createDistributedObject({ let localObject = distributedObject.createDistributedObject({
name: undefined, name: undefined,
age: undefined, age: undefined,
isVis: true, isVis: true,
parent: undefined, parent: undefined,
list: undefined list: undefined
}); });
var sessionId = distributedObject.genSessionId(); let sessionId = distributedObject.genSessionId();
``` ```
4. 加入同步组网。同步组网中的数据对象分为发起方和被拉起方。 4. 加入同步组网。同步组网中的数据对象分为发起方和被拉起方。
以下为加入同步组网的代码示例:
```js ```js
// 发起方 // 发起方
var local_object = distributedObject.createDistributedObject({ let localObject = distributedObject.createDistributedObject({
name: "jack", name: "jack",
age: 18, age: 18,
isVis: true, isVis: true,
parent: { mother: "jack mom", father: "jack Dad" }, parent: { mother: "jack mom", father: "jack Dad" },
list: [{ mother: "jack mom" }, { father: "jack Dad" }] list: [{ mother: "jack mom" }, { father: "jack Dad" }]
}); });
local_object.setSessionId(sessionId); localObject.setSessionId(sessionId);
// 被拉起方 // 被拉起方
var remote_object = distributedObject.createDistributedObject({ let remoteObject = distributedObject.createDistributedObject({
name: undefined, name: undefined,
age: undefined, age: undefined,
isVis: true, isVis: true,
parent: undefined, parent: undefined,
list: undefined list: undefined
}); });
// 收到status上线后remote_object同步数据,即name变成jack,age是18 // 收到status上线后remoteObject同步数据,即name变成jack,age是18
remote_object.setSessionId(sessionId); remoteObject.setSessionId(sessionId);
``` ```
5. 监听对象数据变更。可监听对端数据的变更,以callback作为变更回调实例。
以下为监听对象数据变更的代码示例。 5. 监听对象数据变更。可监听对端数据的变更,以Callback作为变更回调实例。
```js ```js
function changeCallback(sessionId, changeData) { function changeCallback(sessionId, changeData) {
...@@ -178,99 +172,88 @@ ...@@ -178,99 +172,88 @@
if (changeData != null && changeData != undefined) { if (changeData != null && changeData != undefined) {
changeData.forEach(element => { changeData.forEach(element => {
console.info("changed !" + element + " " + local_object[element]); console.info("changed !" + element + " " + localObject[element]);
}); });
} }
} }
// 发起方要在changeCallback里刷新界面,则需要将正确的this绑定给changeCallback // 发起方要在changeCallback里刷新界面,则需要将正确的this绑定给changeCallback
local_object.on("change", this.changeCallback.bind(this)); localObject.on("change", this.changeCallback.bind(this));
``` ```
6. 修改对象属性,对象属性支持基本类型(数字类型、布尔类型、字符串类型)以及复杂类型(数组、基本类型嵌套等)。 6. 修改对象属性,对象属性支持基本类型(数字类型、布尔类型、字符串类型)以及复杂类型(数组、基本类型嵌套等)。
以下为修改分布式数据对象属性的代码示例:
```js ```js
local_object.name = "jack"; localObject.name = "jack";
local_object.age = 19; localObject.age = 19;
local_object.isVis = false; localObject.isVis = false;
local_object.parent = { mother: "jack mom", father: "jack Dad" }; localObject.parent = { mother: "jack mom", father: "jack Dad" };
local_object.list = [{ mother: "jack mom" }, { father: "jack Dad" }]; localObject.list = [{ mother: "jack mom" }, { father: "jack Dad" }];
``` ```
> **说明:** > **说明:**
> 针对复杂类型的数据修改,目前支持对根属性的修改,暂不支持对下级属性的修改。示例如下: > 针对复杂类型的数据修改,目前支持对根属性的修改,暂不支持对下级属性的修改。
```js ```js
// 支持的修改方式 // 支持的修改方式
local_object.parent = { mother: "mom", father: "dad" }; localObject.parent = { mother: "mom", father: "dad" };
// 不支持的修改方式 // 不支持的修改方式
local_object.parent.mother = "mom"; localObject.parent.mother = "mom";
``` ```
7. 访问对象。可以通过直接获取的方式访问到分布式数据对象的属性,且该数据为组网内的最新数据。 7. 访问对象。可以通过直接获取的方式访问到分布式数据对象的属性,且该数据为组网内的最新数据。
以下为访问对象的代码示例:
```js ```js
console.info("name " + local_object["name"]); console.info("name " + localObject["name"]);
``` ```
8. 删除监听数据变更。可以指定删除监听的数据变更回调;也可以不指定,这将会删除该分布式数据对象的所有数据变更回调。 8. 删除监听数据变更。可以指定删除监听的数据变更回调;也可以不指定,这将会删除该分布式数据对象的所有数据变更回调。
以下为取消监听数据变更的代码示例:
```js ```js
// 删除变更回调changeCallback // 删除变更回调changeCallback
local_object.off("change", changeCallback); localObject.off("change", changeCallback);
// 删除所有的变更回调 // 删除所有的变更回调
local_object.off("change"); localObject.off("change");
``` ```
9. 监听分布式对象的上下线。可以监听对端分布式数据对象的上下线。 9. 监听分布式对象的上下线。可以监听对端分布式数据对象的上下线。
以下为访问对象的代码示例:
```js ```js
function statusCallback(sessionId, networkId, status) { function statusCallback(sessionId, networkId, status) {
this.response += "status changed " + sessionId + " " + status + " " + networkId; this.response += "status changed " + sessionId + " " + status + " " + networkId;
} }
local_object.on("status", this.statusCallback); localObject.on("status", this.statusCallback);
``` ```
10. 保存和撤回已保存的数据对象。 10. 保存和撤回已保存的数据对象。
```js ```js
// 保存数据对象 // 保存数据对象
g_object.save("local").then((result) => { localObject.save("local").then((result) => {
console.info("save sessionId " + result.sessionId); console.info("save sessionId " + result.sessionId);
console.info("save version " + result.version); console.info("save version " + result.version);
console.info("save deviceId " + result.deviceId); console.info("save deviceId " + result.deviceId);
}, (result) => { }, (result) => {
console.info("save local failed."); console.info("save local failed.");
}); });
// 撤回保存的数据对象 // 撤回保存的数据对象
g_object.revokeSave().then((result) => { localObject.revokeSave().then((result) => {
console.info("revokeSave success."); console.info("revokeSave success.");
}, (result) => { }, (result) => {
console.info("revokeSave failed."); console.info("revokeSave failed.");
}); });
``` ```
11. 删除监听分布式对象的上下线。可以指定删除监听的上下线回调;也可以不指定,这将会删除该分布式数据对象的所有上下线回调。 11. 删除监听分布式对象的上下线。可以指定删除监听的上下线回调;也可以不指定,这将会删除该分布式数据对象的所有上下线回调。
以下为取消监听数据变更的代码示例:
```js ```js
// 删除上下线回调statusCallback // 删除上下线回调statusCallback
local_object.off("status", this.statusCallback); localObject.off("status", this.statusCallback);
// 删除所有的上下线回调 // 删除所有的上下线回调
local_object.off("status"); localObject.off("status");
``` ```
12. 退出同步组网。分布式对象退出组网后,本地的数据变更对端不会同步。 12. 退出同步组网。分布式对象退出组网后,本地的数据变更对端不会同步。
以下为退出同步组网的代码示例:
```js ```js
local_object.setSessionId(""); localObject.setSessionId("");
``` ```
## 相关实例 ## 相关实例
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册