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

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

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

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

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

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-19 09:29 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

啟動指定頁面

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

調(diào)用方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}`);
  });
})()

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

// GlobalContext.ts 構(gòu)造單例對象
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();

在目標(biāo)端頁面的自定義組件中獲取包含頁面信息的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'))
  }
}

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

調(diào)用方的頁面中實現(xiàn)按鈕點擊觸發(fā)startAbility方法啟動目標(biāo)端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

目標(biāo)端PageAbility的onCreate生命周期回調(diào)中通過featureAbility的getWant方法獲取want,并對參數(shù)進(jìn)行解析,實現(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();

審核編輯 黃宇

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

    關(guān)注

    60

    文章

    2613

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

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

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

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

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

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

    鴻蒙原生頁面高性能解決方案上線OpenHarmony社區(qū) 助力打造高性能原生應(yīng)用

    NEXT的原生頁面高性能解決方案,從頁面滑動、跳轉(zhuǎn)及應(yīng)用冷啟動等關(guān)鍵環(huán)節(jié),為開發(fā)者提供全面的支持。目前,這些解決方案均已上線OpenHarmony開源社區(qū),可在OpenHarmony
    發(fā)表于 01-02 18:00

    Get這個秘籍,鴻蒙原生應(yīng)用頁面滑動絲滑無比

    鴻蒙應(yīng)用開發(fā)中,部分應(yīng)用頁面在滑動時會出現(xiàn)白塊或白屏的問題,不僅困擾開發(fā)者,還直接影響用戶體驗。針對這一痛點,華為近期分別推出了針對鴻蒙
    發(fā)表于 03-06 14:41

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    【HarmonyOS 5】鴻蒙頁面和組件生命周期函數(shù)

    【HarmonyOS 5】鴻蒙頁面和組件生命周期函數(shù) ##鴻蒙開發(fā)能力 ##HarmonyOS SDK應(yīng)用服務(wù)##鴻蒙金融類應(yīng)用 (金融理財
    的頭像 發(fā)表于 07-11 18:24 ?261次閱讀