华为鸿蒙 使用router跳转页面 和 router.getParams接收参数并使用参数 [最简单 最直接 的详细教程 ]

1, 准备两个页面 

1. pages/DetailPage.ets

2. pages/Index.ets

2, 代码直接 cv   页面 // pages/Index.ets

import router from '@ohos.router'

// 参数类型
class User {
  name: string
  age: number
}

@Entry
@Component
struct Index {

  // 要传的参数
  @State
  user: User = {
    name: 'John',
    age: 30
  }


  build() {
    Column({space:15}){
      Text('index page')
        .fontSize('40')
      Button('jump to detail page')
        .onClick(()=>{
        //   1. 跳转页面
          router.pushUrl(
            {
              url:'pages/DetailPage',
              params: this.user // 传参
            }
          )

        //   2. 跳转  替换页面
        //      router.replaceUrl({ url:'pages/DetailPage'})
        })
    }
    .width('100%')
    .height('100%')
    .justifyContent(FlexAlign.Center)
  }
}

 

3, 直接 cv 代码 pages/DetailPage.ets

 

import router from '@ohos.router'
import promptAction from '@ohos.promptAction'

@Entry
@Component
struct DetailPage {
  // 第一中方法接收参数
  @State
  title: string = router.getParams()?.['name']

  // 第二种方法接收参数
  aboutToAppear(){
    const  params = router.getParams()
    // 打印参数 params 打印出来是一个对象
    console.log('11111',params)
    promptAction.showToast({ message: params['name'] + params['age'] })
  }

  build() {
    Column({space:15}){
      Text('Detail page')
        .fontSize(40)
      // 使用参数
      Text(this.title)
      Button('back')
        .onClick(()=>{
        //   1. 跳到上一个页面
          router.back()
        })
    }
    .height('100%')
    .width('100%')
    .justifyContent(FlexAlign.Center)
  }
}

 4, 打印参数

  • 39
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值