chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

【HarmonyOS 5】鴻蒙中的UIAbility詳解(三)

HarmonyOS解決方案 ? 來源:HarmonyOS解決方案 ? 作者:HarmonyOS解決方案 ? 2025-06-14 22:32 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

HarmonyOS 5】鴻蒙中的UIAbility詳解(三)

##鴻蒙開發(fā)能力 ##HarmonyOS SDK應用服務##鴻蒙金融類應用 (金融理財#

一、前言

本文是鴻蒙中的UIAbility詳解系列的最終章。主要針對UIAbility的冷啟動和熱啟動,對于want數(shù)據(jù)的處理。UIAbility的備份恢復,UIAbility的接續(xù)等高級功能的概念和使用講解。

二、UIAbility啟動模式:冷啟動與熱啟動的Want數(shù)據(jù)處理

1. 冷啟動(Cold Start)

應用首次啟動或被系統(tǒng)完全終止后重新創(chuàng)建。

冷啟動,應用會從onCreate函數(shù)中進入,通過want參數(shù),我們可以處理其中攜帶的信息。像applink就是uri,deeplink就是parameters?.deepLink,還有推送等。

核心邏輯很簡單,根據(jù)want中對應需要處理的字段信息,進行邏輯處理(跳轉(zhuǎn)目標頁面,數(shù)據(jù)和業(yè)務處理等)。

onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
  const deepLinkData = want.parameters?.deepLink; // 解析深層鏈接參數(shù)
  this.initData(deepLinkData);
}

2. 熱啟動(Warm Start)

應用在后臺運行時被重新激活(如切換任務或接收新事件)。

一般和冷啟動處理是一對兒,處理邏輯也和冷啟動一致。只不過此時應用從onNewWant函數(shù)跳進來。時機也是App已經(jīng)創(chuàng)建了,此時又被激活。

onNewWant(want: Want, launchParam: AbilityConstant.LaunchParam) {
  if (launchParam.launchReason === AbilityConstant.LaunchReason.NEW_WANT) {
    const updateData = want.parameters?.updateData; // 解析熱啟動參數(shù)
    this.refreshUI(updateData);
  }
}

總結(jié):冷熱啟動區(qū)別對比

特性冷啟動熱啟動
觸發(fā)條件首次啟動/進程終止后重啟從后臺喚醒/接收新Want
生命周期入口onCreateonNewWant(單實例)
頁面棧處理重建頁面棧恢復現(xiàn)有頁面棧
Want參數(shù)來源啟動時指定(如圖標點擊、鏈接)運行中動態(tài)傳入(如跨Ability調(diào)用)

3. 源碼示例

// EntryAbility.ets
export default class EntryAbility extends UIAbility {
  private selectPage: string = '';

  // 冷啟動時觸發(fā)
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
    this.parseParams(want); // 解析參數(shù)
  }

  // 熱啟動時觸發(fā)
  onNewWant(want: Want, launchParam: AbilityConstant.LaunchParam) {
    this.parseParams(want); // 解析參數(shù)
    if (this.currentWindowStage) {
      this.onWindowStageCreate(this.currentWindowStage); // 重新加載頁面
    }
  }

  // 解析參數(shù)邏輯
  private parseParams(want: Want) {
    if (want.parameters?.params) {
      const params = JSON.parse(want.parameters.params as string);
      this.selectPage = params.targetPage; // 獲取目標頁面標識(funA/funB)
    }
  }

  // 加載頁面
  onWindowStageCreate(windowStage: window.WindowStage) {
    let targetPage = 'pages/Index'; // 默認頁面
    switch (this.selectPage) {
      case 'funA': targetPage = 'pages/FunA'; break;
      case 'funB': targetPage = 'pages/FunB'; break;
    }
    windowStage.loadContent(targetPage); // 加載對應頁面
  }
}

二、UIAbility備份恢復:保障異常終止后的狀態(tài)延續(xù)

應用因系統(tǒng)資源不足被后臺終止時,自動保存狀態(tài)。
下次啟動時還原數(shù)據(jù)(如編輯中的內(nèi)容、頁面位置)。

1. 啟用備份功能

onCreate中調(diào)用setRestoreEnabled(true)

export default class EntryAbility extends UIAbility {
  onCreate() {
    this.context.setRestoreEnabled(true); // 初始化時啟用備份
  }
}

2. 保存自定義數(shù)據(jù)

重寫onSaveState方法,通過WantParams存儲數(shù)據(jù):

onSaveState(state: AbilityConstant.StateType, wantParams: Record< string, Object >) {
  wantParams["editorContent"] = this.editor.getText(); // 保存編輯內(nèi)容
  wantParams["currentPage"] = this.router.getCurrentPage(); // 保存頁面路由
  return AbilityConstant.OnSaveResult.ALL_AGREE;
}

3. 恢復數(shù)據(jù)

onCreateonNewWant中解析參數(shù):

onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
  if (want.parameters?.editorContent) {
    this.editor.setText(want.parameters.editorContent as string); // 恢復文本
    this.router.navigateTo(want.parameters.currentPage as string); // 恢復頁面路由
  }
}

注意

1. 數(shù)據(jù)限制 :單次備份最大200KB,存儲時效7天,重啟設備不保留。
2. 適用場景 :臨時數(shù)據(jù)(如未保存的表單)、頁面狀態(tài)(如滾動位置), 不建議存儲敏感數(shù)據(jù) 。
3. 性能優(yōu)化 :避免在onSaveState中執(zhí)行耗時操作,優(yōu)先存儲關(guān)鍵狀態(tài)。

三、應用接續(xù)(Continuation):跨設備任務無縫遷移

將當前頁面狀態(tài)、路由信息遷移至另一設備(如手機→平板)。
支持按場景開啟/關(guān)閉遷移(如僅在編輯頁允許遷移)。
小數(shù)據(jù)通過wantParam傳輸(≤100KB),大數(shù)據(jù)使用分布式數(shù)據(jù)對象(DDO)。

1. 配置可遷移能力

module.json5中設置continuable: true

{
  "abilities": [
    {
      "name": "EditorAbility",
      "continuable": true // 啟用跨設備遷移
    }
  ]
}

2. 源端(發(fā)起遷移設備)實現(xiàn)

onContinue回調(diào):保存數(shù)據(jù)、校驗兼容性、決定是否遷移。

onContinue(wantParam: Record< string, Object >): OnContinueResult {
  // 校驗目標設備版本
  if (wantParam.version < MIN_SUPPORT_VERSION) return MISMATCH;
  
  // 保存編輯內(nèi)容
  wantParam["editorData"] = this.editor.getData();
  
  // 動態(tài)控制遷移狀態(tài)(如僅在編輯頁允許遷移)
  if (this.currentPage !== 'EditorPage') return REJECT;
  
  return AGREE;
}

4. 目標端(接收設備)恢復

冷啟動時通過onCreate恢復,熱啟動時通過onNewWant恢復:

onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) {
  if (launchParam.launchReason === CONTINUATION) {
    const editorData = want.parameters?.editorData;
    this.editor.setData(editorData); // 恢復數(shù)據(jù)
    this.context.restoreWindowStage(); // 自動恢復頁面棧
  }
}

注意

1. 針對動態(tài)開關(guān)遷移 :通過setMissionContinueState控制(如在非編輯頁禁用):

// 在非編輯頁關(guān)閉遷移
this.context.setMissionContinueState(AbilityConstant.ContinueState.INACTIVE);

2. 針對自定義頁面棧 :關(guān)閉自動恢復,手動指定目標頁面:

onContinue(wantParam) {
  wantParam[wantConstant.Params.SUPPORT_CONTINUE_PAGE_STACK_KEY] = false; // 禁用自動恢復
  wantParam["targetPage"] = "SummaryPage"; // 自定義目標頁面
}

3. 針對大數(shù)據(jù)遷移 :使用分布式數(shù)據(jù)對象(DDO)同步文件或大文本:

// 源端創(chuàng)建DDO并保存
const ddo = distributedDataObject.create(this.context, largeData);
wantParam["ddoSessionId"] = ddo.genSessionId(); // 傳遞會話ID至目標端

審核編輯 黃宇

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

    關(guān)注

    60

    文章

    3012

    瀏覽量

    46154
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2156

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

    深入理解HarmonyOS UIAbility:生命周期、WindowStage與啟動模式探析

    UIAbility組件概述 UIAbility組件是HarmonyOS中一種包含UI界面的應用組件,主要用于與用戶進行交互。每個UIAbility組件實例對應最近任務列表
    的頭像 發(fā)表于 02-17 15:33 ?3149次閱讀
    深入理解<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>UIAbility</b>:生命周期、WindowStage與啟動模式探析

    HarmonyOS開發(fā)案例:【UIAbility內(nèi)和UIAbility間頁面的跳轉(zhuǎn)】

    基于Stage模型下的UIAbility開發(fā),實現(xiàn)UIAbility內(nèi)和UIAbility間頁面的跳轉(zhuǎn)。
    的頭像 發(fā)表于 05-09 15:06 ?2773次閱讀
    <b class='flag-5'>HarmonyOS</b>開發(fā)案例:【<b class='flag-5'>UIAbility</b>內(nèi)和<b class='flag-5'>UIAbility</b>間頁面的跳轉(zhuǎn)】

    鴻蒙Ability Kit(程序框架服務)【UIAbility內(nèi)和UIAbility間頁面的跳轉(zhuǎn)】

    基于Stage模型下的UIAbility開發(fā),實現(xiàn)UIAbility內(nèi)和UIAbility間頁面的跳轉(zhuǎn)。
    的頭像 發(fā)表于 06-03 14:13 ?1980次閱讀
    <b class='flag-5'>鴻蒙</b>Ability Kit(程序框架服務)【<b class='flag-5'>UIAbility</b>內(nèi)和<b class='flag-5'>UIAbility</b>間頁面的跳轉(zhuǎn)】

    HarmonyOS 5】VisionKit人臉活體檢測詳解

    HarmonyOS 5】VisionKit人臉活體檢測詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應用服務##
    的頭像 發(fā)表于 06-21 11:52 ?1065次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】VisionKit人臉活體檢測<b class='flag-5'>詳解</b>

    HarmonyOS 5 makeObserved接口詳解

    HarmonyOS 5】makeObserved接口詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應用服務##
    的頭像 發(fā)表于 06-16 17:58 ?788次閱讀

    HarmonyOS 5鴻蒙應用隱私保護詳解

    HarmonyOS 5鴻蒙應用隱私保護詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK
    的頭像 發(fā)表于 07-11 18:30 ?1392次閱讀

    HarmonyOS 5鴻蒙中進度條的使用詳解

    HarmonyOS 5鴻蒙中進度條的使用詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SD
    的頭像 發(fā)表于 07-11 18:26 ?1264次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】<b class='flag-5'>鴻蒙</b>中進度條的使用<b class='flag-5'>詳解</b>

    HarmonyOS 5鴻蒙星閃NearLink詳解

    HarmonyOS 5鴻蒙星閃NearLink詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS
    的頭像 發(fā)表于 07-11 18:24 ?2028次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】<b class='flag-5'>鴻蒙</b>星閃NearLink<b class='flag-5'>詳解</b>

    HarmonyOS 5鴻蒙mPaaS詳解

    HarmonyOS 5鴻蒙mPaaS詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應
    的頭像 發(fā)表于 07-11 18:23 ?1000次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】<b class='flag-5'>鴻蒙</b>mPaaS<b class='flag-5'>詳解</b>

    HarmonyOS 5】金融應用開發(fā)鴻蒙組件實踐

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

    HarmonyOS 5鴻蒙UIAbility詳解(二)

    HarmonyOS 5鴻蒙UIAbility詳解(二) ##
    的頭像 發(fā)表于 07-11 18:17 ?1019次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】<b class='flag-5'>鴻蒙</b><b class='flag-5'>中</b>的<b class='flag-5'>UIAbility</b><b class='flag-5'>詳解</b>(二)

    HarmonyOS 5】桌面快捷方式功能實現(xiàn)詳解

    HarmonyOS 5】桌面快捷方式功能實現(xiàn)詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應用服務##
    的頭像 發(fā)表于 06-21 16:42 ?2424次閱讀
    【<b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b>】桌面快捷方式功能實現(xiàn)<b class='flag-5'>詳解</b>

    HarmonyOS 5 入門系列 】鴻蒙HarmonyOS示例項目講解

    HarmonyOS 5 入門系列 】鴻蒙HarmonyOS示例項目講解 ##鴻蒙開發(fā)能力 ##Har
    的頭像 發(fā)表于 07-07 11:57 ?1184次閱讀
    【 <b class='flag-5'>HarmonyOS</b> <b class='flag-5'>5</b> 入門系列 】<b class='flag-5'>鴻蒙</b><b class='flag-5'>HarmonyOS</b>示例項目講解

    鴻蒙Stage模型與FA模型詳解

    HarmonyOS 5鴻蒙Stage模型與FA模型詳解 ##鴻蒙開發(fā)能力 ##
    的頭像 發(fā)表于 07-07 11:50 ?1062次閱讀

    鴻蒙應用px,vp,fp概念詳解

    HarmonyOS 5鴻蒙應用px,vp,fp概念詳解 ##鴻蒙開發(fā)能力 ##HarmonyOS
    的頭像 發(fā)表于 07-07 11:48 ?1550次閱讀
    <b class='flag-5'>鴻蒙</b>應用px,vp,fp概念<b class='flag-5'>詳解</b>