鸿蒙4.0开发笔记之DevEco Studio页面操作router的pushUrl页面跳转与back返回上一页(五)

一、认识组件

关于HarmonyOS中ArkTS的基础组件请参见文章鸿蒙4.0开发笔记之ArkTs语言基础与基本组件结构(四)

二、实现页面跳转pushUrl

1、操作说明

实现页面跳转的核心便是router.pushUrl的调用,操作起来也很简单,总共就四步。实现步骤如下:

(1)在项目列表的page目录下创建一个新的页面

(2)创建button,并设定基本属性方法

(3)给button添加onclick事件方法

(4)在事件方法中调用router.pushUrl()事件方法,并设定需要跳转的页面的路径。

typescript 复制代码
.onClick(()=>{
          //执行跳转到Target页面:使用router路由可以指定跳转到某个url页面
          router.pushUrl({
            //在entry>src>main>resources>base>profile>main_pages.json中可以找到整个项目所有的页面
            url:"pages/Target"
          })
        })

注意:可以在项目路径下的entry>src>main>resources>base>profile>main_pages.json中找到整个项目所有的页面。

2、实现代码
typescript 复制代码
import router from '@ohos.router'
@Entry
@Component
struct Arrow {
  @State message: string = '鸿蒙Next'

  build() {
    Column() {
      Text(this.message)
        .fontSize(50)
        .fontWeight(FontWeight.Bold)
      Button('点我跳转')
        .fontSize(30)
        .width('50%')
        .height('50vp')
        //跳转页面动作
        .onClick(()=>{
          //执行跳转到Target页面:使用router路由可以指定跳转到某个url页面
          router.pushUrl({
            //在entry>src>main>resources>base>profile>main_pages.json中可以找到整个项目所有的页面
            url:"pages/Target"
          })
        })
    }

    //设置Column容器的宽、高
    .width('100%')
    .height('100%')
  }
}

最终的实现效果就是,点击页面上的"点我跳转"按钮,就会成功跳转到"Target"页面。

三、返回上一个页面back

当页面跳转到"Target"页面后,如何在该页面返回到上一个页面呢?

其实只需要调用一个router.back()事件方法就OK了。实现代码如下:

typescript 复制代码
import router from '@ohos.router'
@Entry
@Component
struct Target {
  @State message: string = '无际鹰'

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .fontStyle(FontStyle.Italic)
          .backgroundColor(Color.Blue)
          .fontColor(Color.Orange)
          .onClick(()=>{
            //返回上一个页面,及从哪里跳转来的,就回到哪里去
            router.back()
          })
      }
      .width('100%')
    }
    .height('100%')
  }
}

这样的整体效果就是,在Arrow页面上点击页面上的"点我跳转"按钮,就会成功跳转到Target页面;然后在Target页面点击"无际鹰"就会跳转回Arrow页面。

相关推荐
風清掦1 分钟前
【STM32学习笔记-12】Unix 时间戳、BKP 备份寄存器与 RTC 实时时钟
笔记·stm32·单片机·嵌入式硬件·学习·实时音视频·unix
Ww.xh36 分钟前
鸿蒙系统中HTML与Vue集成方案
vue.js·html·harmonyos
前端不太难1 小时前
鸿蒙游戏 CI/CD:为什么你还在手动打包?
游戏·ci/cd·harmonyos
全栈若城1 小时前
HarmonyOS Pen Kit 实战:手写笔轻捏、双击与取色器完整集成
华为·harmonyos·手写笔·harmonyos6
05候补工程师2 小时前
【408 应用层通关】DNS 域名解析负载博弈、HTTP 延迟计算与邮件协议全家桶详解
网络·经验分享·笔记·网络协议·计算机网络·http
码途漫谈2 小时前
Easy-Vibe高级开发篇阅读笔记(二)——CC教程之Claude Code MCP 完全指南
笔记·ai·开源·ai编程
游乐码2 小时前
c#反射笔记二
笔记·c#
xmdy58662 小时前
Flutter+开源鸿蒙实战|校园易生活Day1 项目初始化搭建+开发环境校验+工程目录规范+第三方库集成+多端屏幕适配+全局底部导航
flutter·开源·harmonyos
YaBingSec3 小时前
网络安全靶场WP:Grafana 任意文件读取漏洞(CVE-2021-43798)
android·笔记·安全·web安全·ssh·grafana
zhangrelay3 小时前
三分钟云课实践速通--C/C++程序设计--
linux·c语言·c++·笔记·学习·ubuntu