在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

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

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

啟動(dòng)指定頁面

當(dāng)PageAbility的啟動(dòng)模式設(shè)置為單例時(shí)(具體設(shè)置方法和典型場景示例見[PageAbility的啟動(dòng)模式],缺省情況下是單實(shí)例模式),若PageAbility已被拉起,再次啟動(dòng)PageAbility會(huì)觸發(fā)onNewWant回調(diào)(即非首次拉起)。應(yīng)用開發(fā)者可以通過want傳遞啟動(dòng)參數(shù),例如開發(fā)者希望指定頁面啟動(dòng)PageAbility,可以通過want中的parameters參數(shù)傳遞pages信息,具體示例代碼如下: 開發(fā)前請(qǐng)熟悉鴻蒙開發(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)造單例對(duì)象
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的啟動(dòng)模式設(shè)置為多實(shí)例模式或?yàn)槭状螁?dòng)單例模式的PageAbility時(shí)(具體設(shè)置方法和典型場景示例見[PageAbility的啟動(dòng)模式]),在調(diào)用方PageAbility中,通過want中的parameters參數(shù)傳遞要啟動(dòng)的指定頁面的pages信息,調(diào)用startAbility()方法啟動(dòng)PageAbility。被調(diào)用方可以在onCreate中使用featureAbility的getWant方法獲取want,再通過調(diào)用router.pushUrl實(shí)現(xiàn)啟動(dòng)指定頁面。

調(diào)用方的頁面中實(shí)現(xiàn)按鈕點(diǎn)擊觸發(fā)startAbility方法啟動(dòng)目標(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,并對(duì)參數(shù)進(jìn)行解析,實(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();

審核編輯 黃宇

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

    關(guān)注

    57

    文章

    2363

    瀏覽量

    42887
收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

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

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

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

    純血鴻蒙開發(fā)教程-運(yùn)行時(shí)動(dòng)態(tài)加載頁面提升性能

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

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

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

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

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

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

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

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

    系統(tǒng)中的HiLog日志工具的具體使用方法。5、鴻蒙應(yīng)用開發(fā)入門資料五:頁面間跳轉(zhuǎn)認(rèn)識(shí)IntentIntent是對(duì)象之間傳遞信息的載體。例如,當(dāng)一個(gè)Ability需要啟動(dòng)另一個(gè)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)的某個(gè)頁面替換當(dāng)前
    發(fā)表于 11-15 10:11

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

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

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

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

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

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

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

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

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

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

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

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

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

    單個(gè)UIAbility組件可以實(shí)現(xiàn)多個(gè)頁面,并在多個(gè)頁面之間跳轉(zhuǎn),這種UIAbility組件內(nèi)部的頁面跳轉(zhuǎn)關(guān)系稱為“頁面棧”,由ArkUI框架統(tǒng)一管理,如下圖中的UIAbility1
    的頭像 發(fā)表于 06-14 10:10 ?433次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>開發(fā)</b>:【<b class='flag-5'>頁面</b>棧及任務(wù)鏈】
    主站蜘蛛池模板: 永久免费看毛片| 国产成人永久在线播放| 一区二区免费在线观看| 午夜特级毛片| 久久精品亚瑟全部免费观看| 亚欧色| 亚洲欧洲无码一区二区三区| 欧美一级特黄aaaaaa在线看片| 狠狠狠色丁香婷婷综合久久88 | 夜夜综合网| 黄色美女网址| yy6080理aa级伦大片一级| 精品一级毛片| 免费网站你懂得| 色老头网址| 亚洲青草视频| 综合网 色天使| 欧美日韩一卡2卡三卡4卡新区 | 97影院理论片在线观看| 黄色18网站| 97色资源| 免费一级毛片清高播放| 色天天综合色天天碰| 午夜影视免费完整高清在线观看网站| 天天摸天天看| 天天看天天爽天天摸天天添| 精品久久香蕉国产线看观看亚洲| 色综合色综合色综合色综合| 福利午夜在线| 亚洲高清不卡视频| 性欧美大战久久久久久久| 欧美视频区| 美女一级免费毛片| 看一级特黄a大片日本片| 免费看三级黄色片| 俺色也| 加勒比日本道| 热久久国产| 色视频在线免费看| 国产成人亚洲综合a∨婷婷| 国产jzjzjz免费大全视频|