本文介绍: 本篇主要是讲了PageAbility、ServiceAbility、DataAbility的基本通讯配置

创建项目

ServiceAbility开发指导

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
config.json中也有配置出现
在这里插入图片描述

启动Service

ets获取servicebundleName

项目bundleName
在这里插入图片描述

servicebundleName
在这里插入图片描述
这里serviceAbility的bundleName也是项目bundleName
这里abilityName项目bundleName+serviceAbility的Name组合而成

示例
比如我上图的示例com.example.myapplicationcom.example.myapplication.ServiceAbility1
可以这么来启动serviceAbility

onPageShow(){ //Page中的项目初始化(我们这里初始化就开始调用service)
    console.info("Index页面显示了")
    let promise = featureAbility.startAbility(
    {
      want:
      {
        bundleName: "com.example.myapplication",
        abilityName: "com.example.myapplication.ServiceAbility1",
      },
    });
}

//serviceAbility会先执行onStart生命周期
//service.ts(我是这样写serviceAbility的)
//export default {
//    onStart() {
        // hilog.info(0x0000, 'testTag', '%{public}s', 'ServiceAbility onStart');
//        console.info("serive1 start")
//	},
//  ....
//}

在这里插入图片描述

DataAbility开发指导

在这里插入图片描述
在这里插入图片描述

接口 描述
onInitialized 在Ability初始化调用,通过此回调方法执行rdb初始化操作
update 更新数据库中的数据
query 查询数据库中的数据
delete 删除一条或多条数据。
normalizeUri uri进行规范化。一个规范化的uri可以支持设备使用持久化、备份还原等,当上下文改变时仍然可以用到相同的数据项。
batchInsert 数据库插入条数据。
denormalizeUri 一个normalizeUri生产的规范化uri转换成非规范化的uri。
insert 数据插入一条数据
openFile 打开一个文件
getFileTypes 获取文件的MIME类型
getType 获取uri指定数据匹配的MIME类型
executeBatch 批量操作数据库中的数据
call 自定义方法
开发Data步骤
创建Data
  1. 需要实现Data中Insert、Query、Update、Delete接口业务内容。保证能够满足数据库存储业务基本需求。BatchInsert与ExecuteBatch接口已经在系统实现遍历逻辑依赖Insert、Query、Update、Delete接口逻辑,来实现数据批量处理
//data.ts(鸿蒙文档中的配置)
import hilog from '@ohos.hilog';
import featureAbility from '@ohos.ability.featureAbility';
import dataAbility from '@ohos.data.dataAbility';
import dataRdb  from '@ohos.data.rdb';

const TABLE_NAME = "book";//表名
const STORE_CONFIG = {name:'book.db'}
const SQL_CREATE_TABLE = 'CREATE TABLE IF NOT EXISTS book(id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, introduction TEXT NOT NULL)' //创建
let rdbStore: dataRdb.RdbStore = undefined //数据存储仓库

export default {
    onInitialized(abilityInfo) {//DataAbility初始化调用
        // hilog.info(0x0000, 'testTag', '%{public}s', 'DataAbility onInitialized');
        console.info("DataAbility onInitialized, abilityInfo:" + abilityInfo.bundleName)
        let context = featureAbility.getContext()//获取当前对象
        dataRdb.getRdbStore(context, STORE_CONFIG, 1, (err, store) => {
            console.info('DataAbility getRdbStore callback')
            store.executeSql(SQL_CREATE_TABLE, [])
            rdbStore = store
        });
    },
    insert(uri, valueBucket, callback) {
        console.info('DataAbility insert start')
        rdbStore.insert(TABLE_NAME, valueBucket, callback)
    },
    batchInsert(uri, valueBuckets, callback) {
        console.info('DataAbility batch insert start')
        for (let i = 0;i < valueBuckets.length; i++) {
            console.info('DataAbility batch insert i=' + i)
            if (i < valueBuckets.length - 1) {
                rdbStore.insert(TABLE_NAME, valueBuckets[i], (err: any, num: number) => {
                    console.info('DataAbility batch insert ret=' + num)
                })
            } else {
                rdbStore.insert(TABLE_NAME, valueBuckets[i], callback)
            }
        }
    },
    query(uri, columns, predicates, callback) {
        console.info('DataAbility query start')
        let rdbPredicates = dataAbility.createRdbPredicates(TABLE_NAME, predicates)
        rdbStore.query(rdbPredicates, columns, callback)
    },
    update(uri, valueBucket, predicates, callback) {
        console.info('DataAbilityupdate start')
        let rdbPredicates = dataAbility.createRdbPredicates(TABLE_NAME, predicates)
        rdbStore.update(valueBucket, rdbPredicates, callback)
    },
    delete(uri, predicates, callback) {
        console.info('DataAbilitydelete start')
        let rdbPredicates = dataAbility.createRdbPredicates(TABLE_NAME, predicates)
        rdbStore.delete(rdbPredicates, callback)
    }
};

当你用以下调用

//service.ts(其中一个ability)
import hilog from '@ohos.hilog';

import featureAbility from '@ohos.ability.featureAbility'
import ohos_data_ability from "@ohos.data.dataAbility"
import ohos_data_rdb from '@ohos.data.rdb'

var urivar = "dataability://com.example.myapplication.DataAbility1"
var DAHelper = featureAbility.acquireDataAbilityHelper(
    urivar
);
var valuesBucket = {"name": "chentianyu"}
var da = new ohos_data_ability.DataAbilityPredicates()
var valArray =new Array("value1");
var cars = new Array({"batchInsert1" : "value1",});

export default {

    insertOne(){
        DAHelper.insert(urivar,valuesBucket,(error, data)=>{
            console.log("DAHelper insert result: " + data)
        })
    },
    onStart() {
        // hilog.info(0x0000, 'testTag', '%{public}s', 'ServiceAbility onStart');
        console.info("serive1 start")
        this.insertOne()
    },

    onStop() {
        hilog.info(0x0000, 'testTag', '%{public}s', 'ServiceAbility onStop');
    },
    onCommand(want, startId) {
        hilog.info(0x0000, 'testTag', '%{public}s', 'ServiceAbility onCommand');
    },

};

启动程序后出现一下日志(Log)
在这里插入图片描述
所以我们要看DataAbility接口开发

其实是dataability:///+bundleName+Name不是dataability://+bundleName+Name,这bundleName和Name上面有讲(ets获取service的bundleName)
在这里插入图片描述
在这里插入图片描述
这样,PageAbility、ServiceAbility、DataAbility就可以联动起来了

原文地址:https://blog.csdn.net/yasinawolaopo/article/details/134607693

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_12721.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注