HarmonyOS开发之路由跳转

文章目录


一、路由跳转模式与实例

跳转模式 有点类似于vue的路由跳转

  • router.pushUrl 保留路由栈,保留当前的页面;
  • router.replaceUrl 销毁当前页面,跳转一个新的页面 ;
  • router.back 返回上个路由栈保存的页面;

跳转实例

  • router.RouterMode.Standard 默认模式 压入栈顶;
  • router.RouterMode.Single 如果跳转的目标页在路由栈中已经存在,那么就会将距离栈顶最近的url放到栈顶,并重新加载。如果不存在 将按照默认模式执行;

1.router.pushUrl

复制代码
import router from '@ohos.router'

//跳转到新的页面 保留当前路由栈
  router.pushUrl(
  {
      //跳转路径
      url:'pages/HomePage',
      //传递参数
       params:{id:1}
   },
       //默认模式
       router.RouterMode.Standard,
    (err) => {
     if(err){
        console.log('路由失败')
     }
   }
    )
})




//接取参数
router.getParams()['id']

2.router.replaceUrl

复制代码
import router from '@ohos.router'

//跳转到新的页面 保留当前路由栈
  router.replaceUrl (
  {
      //跳转路径
      url:'pages/HomePage',
      //传递参数
       params:{id:1}
   },
       //默认模式
       router.RouterMode.Standard,
    (err) => {
     if(err){
        console.log('路由失败')
     }
   }
    )
})




//接取参数
router.getParams()['id']

3.router.back

复制代码
import router from '@ohos.router'

    //1、直接返回
    router.back();
    
    //2、返回到指定页面
    router.back({
       url: 'pages/Info'
   });

 //3、返回到指定页面,并传递自定义参数信息
 router.back({
     url: 'pages/Info',
     params: {
      id:1
    }
 });


//4、系统默认返回询问框
   router.showAlertBeforeBackPage({
      message:'确定返回到login页面吗?'
     })
   router.back()


  
   //5、自定义询问框
   import promptAction from '@ohos.promptAction'

   promptAction.showDialog({
         message:'确定返回到login页面吗?',
         buttons: [
         {
           text: '取消',
           color: '#FF0000'
         },
          {
           text: '确认',
           color: '#0099FF'
           }
         ]
        }).then((result)=>{
          if(result.index === 0){
             console.log('点击了取消按钮')
          }else if(result.index === 1){
             // 用户点击了"确认"按钮
             console.log('用户点击了"确认"按钮')
            // 调用router.back()方法,返回上一个页面
              router.back();
            }
         }).catch(err => {
           console.error(`Invoke showDialog failed, code is ${err.code}, message is ${err.message}`);
       })
    })
相关推荐
御承扬1 小时前
鸿蒙原生系列之动画效果(转场动画)
华为·harmonyos·转场动画
子榆.1 小时前
Flutter 与开源鸿蒙(OpenHarmony)深度集成实战:从零构建跨平台应用
flutter·开源·harmonyos
luxy20042 小时前
HarmonyOS 5.0 WiFi连接调试工具
华为·harmonyos
夏小鱼的blog2 小时前
【HarmonyOS应用开发入门】 第二期:Stage模型与应用架构解析
harmonyos·开源鸿蒙
养猪喝咖啡3 小时前
ArkTS 文本输入组件(TextInput)详解
harmonyos
养猪喝咖啡3 小时前
HarmonyOS ArkTS 页面导航(Navigation)全面介绍
harmonyos
养猪喝咖啡3 小时前
HarmonyOS ArkTS 从 Router 到 Navigation 的迁移指南
harmonyos
养猪喝咖啡3 小时前
HarmonyOS ArkTS Stack 实战:做一个“悬浮按钮 + 遮罩弹层 + 底部菜单”的完整小项目
harmonyos
Archilect3 小时前
从几何到路径:ArkUI 下的双层容器、缩放偏移与抛掷曲线设计
harmonyos
养猪喝咖啡3 小时前
HarmonyOS ArkTS 创建网格 Grid/GridItem:写得顺、适配稳、滚动不卡的那套方法
harmonyos