一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

鴻蒙OS開發(fā)實(shí)例:【工具類封裝-emitter組件間通信】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-03-27 22:13 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

import Emitter from '@ohos.events.emitter';
import pasteboard from '@ohos.pasteboard';

MyEmitterUtil 是一個(gè)針對 HarmonyOS 的事件驅(qū)動(dòng)編程封裝類,主要用于組件間的通信和數(shù)據(jù)傳遞。

使用要求:

  • DevEco Studio 3.1.1 Release 或更高版本
  • API 版本:api 9 或更高

示例用法:

  1. 父組件綁定、解綁、向子組件發(fā)送事件:

    aboutToAppear() {
      this.myEmitterUtil.onFather((eventData: EmitterData) = > {
         console.info('父組件監(jiān)聽結(jié)果: ', JSON.stringify(eventData));
         // 判斷事件類型并執(zhí)行相應(yīng)操作...
       });
    }
    
     aboutToDisappear() {
       this.myEmitterUtil.offFather();
     }
    
     // 向子組件發(fā)送事件
     this.myEmitterUtil.emitChild(MyEmitterUtil.UPDATE_DETAIL, "攜帶的測試數(shù)據(jù)");
    
  2. 子組件綁定、解綁、向父組件發(fā)送事件:

    aboutToAppear() {
    this.myEmitterUtil.onChild((eventData: EmitterData) = > {
    console.info('子組件監(jiān)聽結(jié)果: ', JSON.stringify(eventData));
    // 判斷事件類型并執(zhí)行相應(yīng)操作...
    });
    }
    
    aboutToDisappear() {
    this.myEmitterUtil.offChild();
    }
    
    // 向父組件發(fā)送事件
    this.myEmitterUtil.emitFather(MyEmitterUtil.UPDATE_LIST, "測試");
    this.myEmitterUtil.emitFather(MyEmitterUtil.UPDATE_LIST_2, "測試2");
    
    
    

參考文檔:

請查閱 HarmonyOS 開發(fā)文檔了解詳細(xì)信息。

export class MyEmitterUtil {
  private static readonly LOG_TAG = 'MyEmitterUtil';
  private static EVENT_ID_COUNTER: number = 0; // 自動(dòng)遞增,生成唯一的事件ID

  private readonly eventIdFather: number;
  private readonly eventIdChild: number;

  constructor() {
    this.eventIdFather = MyEmitterUtil.EVENT_ID_COUNTER++;
    this.eventIdChild = MyEmitterUtil.EVENT_ID_COUNTER++;
    console.info(`事件ID(父組件): ${this.eventIdFather}`);
    console.info(`事件ID(子組件): ${this.eventIdChild}`);
  }

  // 定義業(yè)務(wù)狀態(tài)標(biāo)識(shí)常量
  static readonly UPDATE_LIST = "UPDATE_LIST";
  static readonly UPDATE_LIST_2 = "UPDATE_LIST_2";
  static readonly UPDATE_DETAIL = "UPDATE_DETAIL";

  /**
   * 在組件的`aboutToAppear`生命周期鉤子中調(diào)用,監(jiān)聽父組件事件
   * @param callback 事件回調(diào)函數(shù),接受一個(gè)`EmitterData`對象作為參數(shù)
   */
  onFather(callback: (eventData: EmitterData) = > void) {
    Emitter.on({ eventId: this.eventIdFather }, (event) = > {
      if (callback) {
        callback(new EmitterData(event.data.flag, event.data.data));
      }
    });
  }

  /**
   * 在組件的`aboutToDisappear`生命周期鉤子中調(diào)用,解除父組件事件監(jiān)聽
   */
  offFather() {
    Emitter.off(this.eventIdFather);
  }

  /**
   * 在組件的`aboutToAppear`生命周期鉤子中調(diào)用,監(jiān)聽子組件事件
   * @param callback 事件回調(diào)函數(shù),接受一個(gè)`EmitterData`對象作為參數(shù)
   */
  onChild(callback: (eventData: EmitterData) = > void) {
    Emitter.on({ eventId: this.eventIdChild }, (event) = > {
      if (callback) {
        callback(new EmitterData(event.data.flag, event.data.data));
      }
    });
  }

  /**
   * 在組件的`aboutToDisappear`生命周期鉤子中調(diào)用,解除子組件事件監(jiān)聽
   */
  offChild() {
    Emitter.off(this.eventIdChild);
  }

  /**
   * 向父組件發(fā)送事件
   * @param flag 事件類型標(biāo)識(shí)
   * @param data 事件攜帶的數(shù)據(jù)
   */
  emitFather(flag: string, data: string) {
    Emitter.emit(
      { eventId: this.eventIdFather, priority: Emitter.EventPriority.IMMEDIATE },
      { data: { flag, data } }
    );
  }

  /**
   * 向子組件發(fā)送事件
   * @param flag 事件類型標(biāo)識(shí)
   * @param data 事件攜帶的數(shù)據(jù)
   */
  emitChild(flag: string, data: string) {
    Emitter.emit(
      { eventId: this.eventIdChild, priority: Emitter.EventPriority.IMMEDIATE },
      { data: { flag, data } }
    );
  }
}

/**
 * 用于封裝事件數(shù)據(jù)的類
 */
export class EmitterData {
  flag: string = "";
  data: string = "";

  constructor(flag: string, data: string) {
    this.flag = flag;
    this.data = data;
  }
}

/**
 * 獲取剪貼板內(nèi)容的輔助函數(shù)
 */
export async function getPasteboardContent(): Promise< void > {
  try {
    const systemPasteboard = pasteboard.getSystemPasteboard();
    const pasteData = await systemPasteboard.getData();
    const text = pasteData.getPrimaryText();
    console.info('剪貼板內(nèi)容: ', text);
  } catch (e) {
    console.error('獲取剪貼板內(nèi)容失敗: ', JSON.stringify(e));
  }
}

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 封裝
    +關(guān)注

    關(guān)注

    128

    文章

    8685

    瀏覽量

    145516
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2126

    瀏覽量

    33101
  • 鴻蒙OS
    +關(guān)注

    關(guān)注

    0

    文章

    191

    瀏覽量

    4998
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    【HarmonyOS 5】金融應(yīng)用開發(fā)鴻蒙組件實(shí)踐

    【HarmonyOS 5】金融應(yīng)用開發(fā)鴻蒙組件實(shí)踐 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應(yīng)用服務(wù)##
    的頭像 發(fā)表于 07-11 18:20 ?289次閱讀
    【HarmonyOS 5】金融應(yīng)用<b class='flag-5'>開發(fā)</b><b class='flag-5'>鴻蒙</b><b class='flag-5'>組件</b>實(shí)踐

    harmony-utils之EmitterUtil,Emitter工具

    harmony-utils之EmitterUtil,Emitter工具
    的頭像 發(fā)表于 07-03 18:24 ?143次閱讀

    harmony-utils之JSONUtil,JSON工具

    ,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程通信
    的頭像 發(fā)表于 07-03 18:21 ?149次閱讀

    harmony-utils之LocationUtil,定位相關(guān)工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 07-03 18:13 ?145次閱讀

    harmony-utils之LogUtil,日志工具

    ,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程通信
    的頭像 發(fā)表于 07-03 18:12 ?144次閱讀

    harmony-utils之LRUCacheUtil,LRUCache緩存工具

    ,借助眾多實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授
    的頭像 發(fā)表于 07-03 18:11 ?139次閱讀

    harmony-utils之PreviewUtil,文件預(yù)覽工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 07-03 11:40 ?122次閱讀

    harmony-utils之RegexUtil,正則工具

    ,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程
    的頭像 發(fā)表于 07-03 11:38 ?120次閱讀

    harmony-utils之StrUtil,字符串工具

    ,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程通信
    的頭像 發(fā)表于 07-03 11:32 ?100次閱讀

    harmony-utils之ToastUtil,吐司工具

    ,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程
    的頭像 發(fā)表于 06-30 17:35 ?112次閱讀

    harmony-utils之TypeUtil,類型檢查工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 06-30 17:35 ?114次閱讀

    harmony-utils之WantUtil,Want工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 06-30 17:34 ?119次閱讀

    harmony-utils之WindowUtil,窗口相關(guān)工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 06-30 17:33 ?122次閱讀

    harmony-utils之SHA,SHA工具

    助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程通信、彈框、
    的頭像 發(fā)表于 06-30 16:51 ?164次閱讀

    harmony-utils之NetworkUtil,網(wǎng)絡(luò)相關(guān)工具

    實(shí)用工具,致力于助力開發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、
    的頭像 發(fā)表于 06-25 23:46 ?52次閱讀