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

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

3天內不再提示

鴻蒙開發(fā):啟動指定頁面

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-19 09:29 ? 次閱讀

啟動指定頁面

當PageAbility的啟動模式設置為單例時(具體設置方法和典型場景示例見[PageAbility的啟動模式],缺省情況下是單實例模式),若PageAbility已被拉起,再次啟動PageAbility會觸發(fā)onNewWant回調(即非首次拉起)。應用開發(fā)者可以通過want傳遞啟動參數(shù),例如開發(fā)者希望指定頁面啟動PageAbility,可以通過want中的parameters參數(shù)傳遞pages信息,具體示例代碼如下: 開發(fā)前請熟悉鴻蒙開發(fā)指導文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

調用方PageAbility的app.ets中或者page中,使用startAbility再次拉起PageAbility,通過want中的uri參數(shù)傳遞頁面信息:

import featureAbility from '@ohos.ability.featureAbility';
import Want from '@ohos.app.ability.Want';
import hilog from '@ohos.hilog';

const TAG: string = 'PagePageAbilityFirst';
const domain: number = 0xFF00;
(async (): Promise< void > = > {
  let wantInfo: Want = {
    bundleName: 'com.samples.famodelabilitydevelop',
    abilityName: 'com.samples.famodelabilitydevelop.PageAbilitySingleton',
    parameters: { page: 'pages/second' }
  };
  featureAbility.startAbility({ want: wantInfo }).then((data) = > {
    hilog.debug(domain, TAG, `restartAbility success : ${data}`);
  });
})()

在目標端PageAbility的onNewWant回調中獲取包含頁面信息的want參數(shù):

// GlobalContext.ts 構造單例對象
export class GlobalContext {
  private constructor() {
  }

  private static instance: GlobalContext;
  private _objects = new Map< string, Object >();

  public static getContext(): GlobalContext {
    if (!GlobalContext.instance) {
      GlobalContext.instance = new GlobalContext();
    }
    return GlobalContext.instance;
  }

  getObject(value: string): Object | undefined {
    return this._objects.get(value);
  }

  setObject(key: string, objectClass: Object): void {
    this._objects.set(key, objectClass);
  }
}
import Want from '@ohos.app.ability.Want';
import featureAbility from '@ohos.ability.featureAbility';
import { GlobalContext } from '../utils/GlobalContext';

class PageAbilitySingleton {
  onNewWant(want: Want) {
    featureAbility.getWant().then((want) = > {
      GlobalContext.getContext().setObject('newWant', want);
    })
  }
}

export default new PageAbilitySingleton();

在目標端頁面的自定義組件中獲取包含頁面信息的want參數(shù)并根據(jù)uri做路由處理:

import Want from '@ohos.app.ability.Want';
import router from '@ohos.router';
import { GlobalContext } from '../../utils/GlobalContext';

@Entry
@Component
struct First {
  onPageShow() {
    let newWant = GlobalContext.getContext().getObject('newWant') as Want;
    if (newWant) {
      if (newWant.parameters) {
        if (newWant.parameters.page) {
          router.pushUrl({ url: newWant.parameters.page as string});
          GlobalContext.getContext().setObject("newWant", undefined)
        }
      }
    }
  }

  build() {
    Column() {
      Row() {
        Text($r('app.string.singleton_first_title'))
          .fontSize(24)
          .fontWeight(FontWeight.Bold)
          .textAlign(TextAlign.Start)
          .margin({ top: 12, bottom: 11, right: 24, left: 24 })
      }
      .width('100%')
      .height(56)
      .justifyContent(FlexAlign.Start)

      Image($r('app.media.pic_empty'))
        .width(120)
        .height(120)
        .margin({ top: 224 })

      Text($r('app.string.no_content'))
        .fontSize(14)
        .margin({ top: 8, bottom: 317, right: 152, left: 152 })
        .fontColor($r('app.color.text_color'))
        .opacity(0.4)
    }
    .width('100%')
    .height('100%')
    .backgroundColor($r('app.color.backGrounding'))
  }
}

當PageAbility的啟動模式設置為多實例模式或為首次啟動單例模式的PageAbility時(具體設置方法和典型場景示例見[PageAbility的啟動模式]),在調用方PageAbility中,通過want中的parameters參數(shù)傳遞要啟動的指定頁面的pages信息,調用startAbility()方法啟動PageAbility。被調用方可以在onCreate中使用featureAbility的getWant方法獲取want,再通過調用router.pushUrl實現(xiàn)啟動指定頁面。

調用方的頁面中實現(xiàn)按鈕點擊觸發(fā)startAbility方法啟動目標端PageAbility,startAbility方法的入?yún)ant中攜帶指定頁面信息,示例代碼如下:

import featureAbility from '@ohos.ability.featureAbility';
import Want from '@ohos.app.ability.Want';
import { BusinessError } from '@ohos.base';
import fs from '@ohos.file.fs';
import promptAction from '@ohos.promptAction';
import worker from '@ohos.worker';
import hilog from '@ohos.hilog';

const TAG: string = 'PagePageAbilityFirst';
const domain: number = 0xFF00;

@Entry
@Component
struct PagePageAbilityFirst {
  build() {
    Column() {
      //...
      List({ initialIndex: 0 }) {
        //...
        ListItem() {
          Flex({ justifyContent: FlexAlign.SpaceBetween, alignContent: FlexAlign.Center }) {
          //...
          }
          .onClick(() = > {
            let want: Want = {
              bundleName: 'com.samples.famodelabilitydevelop',
              abilityName: 'com.samples.famodelabilitydevelop.PageAbilityStandard',
              parameters: { page: 'pages/first' }
            };
            featureAbility.startAbility({ want: want }).then((data) = > {
              hilog.info(domain, TAG, `startAbility finish:${data}`);
            }).catch((err: BusinessError) = > {
              hilog.info(domain, TAG, `startAbility failed errcode:${err.code}`);
            })
          })
        }
        //...
        ListItem() {
          Flex({ justifyContent: FlexAlign.SpaceBetween, alignContent: FlexAlign.Center }) {
          //...
          }
          .onClick(() = > {
            let want: Want = {
              bundleName: 'com.samples.famodelabilitydevelop',
              abilityName: 'com.samples.famodelabilitydevelop.PageAbilityStandard',
              parameters: { page: 'pages/second' }
            };
            featureAbility.startAbility({ want: want }).then((data) = > {
              hilog.info(domain, TAG, `startAbility finish:${data}`);
            }).catch((err: BusinessError) = > {
              hilog.info(domain, TAG, `startAbility failed errcode:${err.code}`);
            })
          })
        }
        //...
      }
      //...
    }
    //...
  }
}

`HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`

鴻蒙文檔.png

目標端PageAbility的onCreate生命周期回調中通過featureAbility的getWant方法獲取want,并對參數(shù)進行解析,實現(xiàn)指定頁面拉起:

import featureAbility from '@ohos.ability.featureAbility';
import router from '@ohos.router';

class PageAbilityStandard {
  onCreate() {
    featureAbility.getWant().then((want) = > {
      if (want.parameters) {
        if (want.parameters.page) {
          router.pushUrl({ url: want.parameters.page as string });
        }
      }
    })
  }
}

export default new PageAbilityStandard();

審核編輯 黃宇

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

    關注

    57

    文章

    2302

    瀏覽量

    42689
收藏 人收藏

    評論

    相關推薦

    鴻蒙OS開發(fā):典型頁面場景【一次開發(fā),多端部署】實戰(zhàn)(設置典型頁面

    本示例展示了設置應用的典型頁面,其在小窗口和大窗口有不同的顯示效果,體現(xiàn)一次開發(fā)、多端部署的能力。
    的頭像 發(fā)表于 05-27 09:36 ?1064次閱讀
    <b class='flag-5'>鴻蒙</b>OS<b class='flag-5'>開發(fā)</b>:典型<b class='flag-5'>頁面</b>場景【一次<b class='flag-5'>開發(fā)</b>,多端部署】實戰(zhàn)(設置典型<b class='flag-5'>頁面</b>)

    鴻蒙Ability開發(fā)-Stage模型下Ability的創(chuàng)建和使用

    ) } ... } 使用windowStage.loadContent為指定Ability設置相關的Page頁面。 // DetailsAbility.ts ... export default class
    發(fā)表于 01-08 15:34

    純血鴻蒙開發(fā)教程-運行時動態(tài)加載頁面提升性能

    ,主頁內存占用增加,加載時間變長。此時改用動態(tài)加載不再提前加載子頁面,可以有效地避免這些任務阻塞主線程,從而降低整體資源消耗,提高主頁的加載速度。 最后 如果大家覺得這篇內容對學習鴻蒙開發(fā)有幫助,我想
    發(fā)表于 05-10 20:52

    鴻蒙OS應用開發(fā)實踐(三)

    ;com.qibiao.harmonyosdemo.NewPage") .build();這串代碼指定了我們要跳轉的目標頁面,需要指定目標的包名,還有Ability名稱(非slice)。最后使用startAbility()接口
    發(fā)表于 12-03 21:54

    鴻蒙OS應用開發(fā)實踐(三)

    簡單的鴻蒙交互程序:從一個頁面跳轉到另一個頁面。 (一)創(chuàng)建工程先創(chuàng)建一個新的TV的empty java工程:點finish后,發(fā)現(xiàn)這次從創(chuàng)建到項目環(huán)境加載完成,用了很短的時間,這是因為初始環(huán)境需要
    發(fā)表于 12-04 08:54

    鴻蒙應用開發(fā)基礎術語學習 輕應用

    開發(fā)者可以通過鴻蒙輕應用,通過點擊關鍵詞解鎖詳細解釋的方式,方便快速第了解鴻蒙的基礎術語??梢元毩⒆鳛橐粋€應用發(fā)展,也可以作為各種應用中的一個模塊。適合HarmonyOS開發(fā)者及潛在
    發(fā)表于 05-19 18:33

    鴻蒙應用開發(fā)入門資料合集

    系統(tǒng)中的HiLog日志工具的具體使用方法。5、鴻蒙應用開發(fā)入門資料五:頁面間跳轉認識IntentIntent是對象之間傳遞信息的載體。例如,當一個Ability需要啟動另一個Abili
    發(fā)表于 03-22 11:23

    鴻蒙原生應用開發(fā)-關于頁面接口router返回問題與解決思路

    一、模塊導入 import router from \'@ohos.router\' 提供通過不同的url訪問不同的頁面,包括跳轉到應用內的指定頁面、用應用內的某個頁面替換當前
    發(fā)表于 11-15 10:11

    米哈游宣布啟動鴻蒙原生應用開發(fā)

    12月18日,米哈游宣布將基于HarmonyOS NEXT啟動鴻蒙原生應用開發(fā),成為又一家啟動鴻蒙原生應用
    的頭像 發(fā)表于 12-18 10:07 ?475次閱讀

    京東正式啟動鴻蒙原生應用開發(fā)

    華為與京東于近日宣布達成一項重要合作,正式啟動鴻蒙原生應用開發(fā)。這一合作旨在利用HarmonyOS NEXT的獨特優(yōu)勢,為消費者提供更出色的購物體驗。
    的頭像 發(fā)表于 01-18 15:02 ?733次閱讀

    多家頭部企業(yè)宣布「啟動鴻蒙原生應用開發(fā)」,你看好鴻蒙系統(tǒng)走向「獨立」嗎?

    鴻蒙生態(tài)迎「關鍵一戰(zhàn)」,多家頭部企業(yè)宣布「啟動鴻蒙原生應用開發(fā)」,你看好鴻蒙系統(tǒng)走向「獨立」嗎?
    的頭像 發(fā)表于 01-24 11:47 ?521次閱讀
    多家頭部企業(yè)宣布「<b class='flag-5'>啟動</b><b class='flag-5'>鴻蒙</b>原生應用<b class='flag-5'>開發(fā)</b>」,你看好<b class='flag-5'>鴻蒙</b>系統(tǒng)走向「獨立」嗎?

    淘寶正式啟動華為鴻蒙原生應用開發(fā)

    華為與淘寶近日宣布,淘寶已正式啟動鴻蒙原生應用開發(fā)。這一合作標志著鴻蒙生態(tài)在電商領域的布局進一步擴大,將為用戶帶來全新的全場景購物體驗。
    的頭像 發(fā)表于 01-26 15:59 ?734次閱讀

    淘寶與華為合作將基于HarmonyOS NEXT啟動鴻蒙原生應用開發(fā)

    1月25日,淘寶與華為舉辦鴻蒙合作簽約儀式,宣布將基于HarmonyOS NEXT啟動鴻蒙原生應用開發(fā)
    的頭像 發(fā)表于 01-26 16:14 ?1024次閱讀

    哪吒汽車APP啟動鴻蒙原生應用開發(fā)

    哪吒汽車正式簽約,啟動鴻蒙原生應用開發(fā);在5月17日,在上海市經(jīng)濟和信息化委員會指導的“千帆競發(fā)啟航 共筑鴻蒙生態(tài)——HDD上海站·鴻蒙原生
    的頭像 發(fā)表于 05-18 09:48 ?1125次閱讀

    鴻蒙開發(fā):【頁面棧及任務鏈】

    單個UIAbility組件可以實現(xiàn)多個頁面,并在多個頁面之間跳轉,這種UIAbility組件內部的頁面跳轉關系稱為“頁面棧”,由ArkUI框架統(tǒng)一管理,如下圖中的UIAbility1
    的頭像 發(fā)表于 06-14 10:10 ?329次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b>:【<b class='flag-5'>頁面</b>棧及任務鏈】