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

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

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

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

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-03-27 22:13 ? 次閱讀

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

MyEmitterUtil 是一個(gè)針對(duì) 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)聽(tīng)結(jié)果: ', JSON.stringify(eventData));
         // 判斷事件類型并執(zhí)行相應(yīng)操作...
       });
    }
    
     aboutToDisappear() {
       this.myEmitterUtil.offFather();
     }
    
     // 向子組件發(fā)送事件
     this.myEmitterUtil.emitChild(MyEmitterUtil.UPDATE_DETAIL, "攜帶的測(cè)試數(shù)據(jù)");
    
  2. 子組件綁定、解綁、向父組件發(fā)送事件:

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

參考文檔:

請(qǐng)查閱 HarmonyOS 開(kāi)發(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)聽(tīng)父組件事件
   * @param callback 事件回調(diào)函數(shù),接受一個(gè)`EmitterData`對(duì)象作為參數(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)聽(tīng)
   */
  offFather() {
    Emitter.off(this.eventIdFather);
  }

  /**
   * 在組件的`aboutToAppear`生命周期鉤子中調(diào)用,監(jiān)聽(tīng)子組件事件
   * @param callback 事件回調(diào)函數(shù),接受一個(gè)`EmitterData`對(duì)象作為參數(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)聽(tīng)
   */
  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)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 封裝
    +關(guān)注

    關(guān)注

    125

    文章

    7593

    瀏覽量

    142145
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1946

    瀏覽量

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

    關(guān)注

    0

    文章

    188

    瀏覽量

    4336
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    鴻蒙OS崛起,鴻蒙應(yīng)用開(kāi)發(fā)工程師成市場(chǎng)新寵

    beta版,為開(kāi)發(fā)者提供了一整套的開(kāi)發(fā)工具和資源,極大地提高了開(kāi)發(fā)效率。 據(jù)了解,通過(guò)螞蟻數(shù)科mPaaS提供的模塊化工具組件
    發(fā)表于 04-29 17:32

    HarmonyOS開(kāi)發(fā)實(shí)例:【自定義Emitter

    使用[Emitter]實(shí)現(xiàn)事件的訂閱和發(fā)布,使用[自定義彈窗]設(shè)置廣告信息。
    的頭像 發(fā)表于 04-14 11:37 ?881次閱讀
    HarmonyOS<b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【自定義<b class='flag-5'>Emitter</b>】

    OpenHarmony開(kāi)發(fā)實(shí)例:【鴻蒙.bin文件燒錄】

    如何使用HiBurn工具燒錄鴻蒙的.bin文件到Hi3861開(kāi)發(fā)板。
    的頭像 發(fā)表于 04-14 09:54 ?306次閱讀
    OpenHarmony<b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【<b class='flag-5'>鴻蒙</b>.bin文件燒錄】

    鴻蒙OS開(kāi)發(fā)實(shí)例:【HarmonyHttpClient】網(wǎng)絡(luò)框架

    鴻蒙上使用的Http網(wǎng)絡(luò)框架,里面包含純Java實(shí)現(xiàn)的HttpNet,類似okhttp使用,支持同步和異步兩種請(qǐng)求方式;還有鴻蒙版retrofit,和Android版Retrofit相似的使用,解放雙手般優(yōu)雅使用注解、自動(dòng)解析json
    的頭像 發(fā)表于 04-12 16:58 ?703次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【HarmonyHttpClient】網(wǎng)絡(luò)框架

    鴻蒙OS開(kāi)發(fā)實(shí)例:【組件化模式】

    組件化一直是移動(dòng)端比較流行的開(kāi)發(fā)方式,有著編譯運(yùn)行快,業(yè)務(wù)邏輯分明,任務(wù)劃分清晰等優(yōu)點(diǎn),針對(duì)Android端的組件化;與Android端的組件化相比,HarmonyOS的
    的頭像 發(fā)表于 04-07 17:44 ?452次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【<b class='flag-5'>組件</b>化模式】

    鴻蒙OS開(kāi)發(fā)實(shí)例:【應(yīng)用狀態(tài)變量共享】

    平時(shí)在開(kāi)發(fā)的過(guò)程中,我們會(huì)在應(yīng)用中共享數(shù)據(jù),在不同的頁(yè)面共享信息。雖然常用的共享信息,也可以通過(guò)不同頁(yè)面中組件信息共享的方式,但有時(shí)使用應(yīng)用級(jí)別的狀態(tài)管理會(huì)讓
    的頭像 發(fā)表于 04-03 15:09 ?1080次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【應(yīng)用狀態(tài)變量共享】

    鴻蒙OS開(kāi)發(fā)實(shí)例:【工具封裝-頁(yè)面路由】

    import common from '@ohos.app.ability.common'; import router from '@ohos.router'封裝app內(nèi)的頁(yè)面之間跳轉(zhuǎn)、app與app之間的跳轉(zhuǎn)工具
    的頭像 發(fā)表于 03-28 16:16 ?741次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【<b class='flag-5'>工具</b><b class='flag-5'>類</b><b class='flag-5'>封裝</b>-頁(yè)面路由】

    鴻蒙OS開(kāi)發(fā)實(shí)例:【工具封裝-http請(qǐng)求】

    ;@ohos.promptAction';** **封裝HTTP接口請(qǐng)求,提供格式化的響應(yīng)信息輸出功能。 使用 DevEco Studio 3.1.1 Release 及以上版本,API 版本為 api 9 及以上
    的頭像 發(fā)表于 03-27 22:32 ?1150次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b><b class='flag-5'>開(kāi)發(fā)</b><b class='flag-5'>實(shí)例</b>:【<b class='flag-5'>工具</b><b class='flag-5'>類</b><b class='flag-5'>封裝</b>-http請(qǐng)求】

    鴻蒙APP開(kāi)發(fā)實(shí)戰(zhàn):【Api9】拍照、拍視頻;選擇圖片、視頻、文件工具

    鴻蒙開(kāi)發(fā)過(guò)程中,經(jīng)常會(huì)進(jìn)行系統(tǒng)調(diào)用,拍照、拍視頻、選擇圖庫(kù)圖片、選擇圖庫(kù)視頻、選擇文件。今天就給大家分享一個(gè)工具。
    的頭像 發(fā)表于 03-26 16:27 ?621次閱讀
    <b class='flag-5'>鴻蒙</b>APP<b class='flag-5'>開(kāi)發(fā)</b>實(shí)戰(zhàn):【Api9】拍照、拍視頻;選擇圖片、視頻、文件<b class='flag-5'>工具</b><b class='flag-5'>類</b>

    鴻蒙OS和開(kāi)源鴻蒙什么關(guān)系?

    內(nèi)核,其他功能都以模塊的形式存在。 ? ? 華為用的是鴻蒙OS 我們都知道,華為手機(jī)的鴻蒙OS是可以運(yùn)行安卓軟件的,是因?yàn)橄到y(tǒng)中有安卓兼容層,所以可以簡(jiǎn)單這么理解:
    的頭像 發(fā)表于 01-30 15:44 ?825次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>OS</b>和開(kāi)源<b class='flag-5'>鴻蒙</b>什么關(guān)系?

    鴻蒙ArkUI開(kāi)發(fā)-Tabs組件的使用

    鴻蒙ArkUI開(kāi)發(fā)-Tabs組件的使用
    的頭像 發(fā)表于 01-19 16:01 ?1413次閱讀
    <b class='flag-5'>鴻蒙</b>ArkUI<b class='flag-5'>開(kāi)發(fā)</b>-Tabs<b class='flag-5'>組件</b>的使用

    鴻蒙開(kāi)發(fā)OpenHarmony組件復(fù)用案例

    ; ...... } 開(kāi)發(fā)實(shí)踐 我們看下組件復(fù)用的實(shí)際使用案例。示例中,會(huì)創(chuàng)建一個(gè)圖片列表頁(yè)面,使用懶加載LazyForEach,以及組件復(fù)用能力。 創(chuàng)建數(shù)據(jù)源 首先,創(chuàng)建了一個(gè)業(yè)務(wù)對(duì)象
    發(fā)表于 01-15 17:37

    鴻蒙開(kāi)發(fā)基礎(chǔ)-Web組件之cookie操作

    }) ... } ... 本文章主要是對(duì)鴻蒙開(kāi)發(fā)當(dāng)中ArkTS語(yǔ)言的基礎(chǔ)應(yīng)用實(shí)戰(zhàn),Web組件里的cookie操作。更多的鴻蒙應(yīng)用開(kāi)發(fā)
    發(fā)表于 01-14 21:31

    華為鴻蒙系統(tǒng)

    華為鴻蒙系統(tǒng)(HUAWEI Harmony OS),是華為公司在2019年8月9日于東莞舉行的華為開(kāi)發(fā)者大會(huì)(HDC.2019)上正式發(fā)布的操作系統(tǒng)。 華為鴻蒙系統(tǒng)是一款全新的面向全場(chǎng)
    發(fā)表于 11-02 19:39

    鴻蒙 OS 應(yīng)用開(kāi)發(fā)初體驗(yàn)

    的操作系統(tǒng)平臺(tái)和開(kāi)發(fā)框架。HarmonyOS 的目標(biāo)是實(shí)現(xiàn)跨設(shè)備的無(wú)縫協(xié)同和高性能。 DevEco Studio 對(duì)標(biāo) Android Studio,開(kāi)發(fā)鴻蒙 OS 應(yīng)用的 IDE。
    發(fā)表于 11-02 19:38