ohos.router页面路由

215 阅读2分钟

导入模块

import router from '@ohos.router'

router.push

push(options: RouterOptions): void

跳转到应用内的指定页面

标题类型必填说明
optionsRouterOptions跳转页面描述信息。
router.push({
  url: 'pages/routerpage2',
  params: {
    data: 'message'
  },
});

router.replace

replace(options: RouterOptions): void

用应用内的某个页面替换当前页面,并销毁被替换的页面。

标题类型必填说明
optionsRouterOptions替换页面描述信息。
router.replace({
  url: 'pages/detail',
  params: {
    data: 'message',
  },
});

router.back

back(options?: RouterOptions ): void

返回上一页面或指定的页面。

标题类型必填说明
optionsRouterOptions返回页面描述信息,其中参数url指路由跳转时会返回到指定url的界面,如果页面栈上没有url页面,则不响应该情况。如果url未设置,则返回上一页。
router.back({url:'pages/detail'});    

router.getParams

getParams(): Object

获取发起跳转的页面往当前页传入的参数。

类型说明
Object发起跳转的页面往当前页传入的参数。
router.getParams();

RouterOptions

路由跳转选项。

名称类型必填说明
urlstring表示目标页面的uri,可以用以下两种格式:页面绝对路径,由配置文件中pages列表提供,例如:pages/index/index,特殊值,如果uri的值是"/",则跳转到首页。
paramsObject表示路由跳转时要同时传递到目标页面的数据。跳转到目标页面后,使用router.getParams()获取传递的参数,此外,在类web范式中,参数也可以在页面中直接使用,如this.keyValue(keyValue为跳转时params参数中的key值),如果目标页面中已有该字段,则其值会被传入的字段值覆盖。

完整实例

基于JS扩展的类Web开发范式
    // 在当前页面中
export default {
  pushPage() {
    router.push({
      url: 'pages/detail/detail',
      params: {
        data: 'message',
      },
    });
  }
}

// 在detail页面中
export default {
  onInit() {
    console.info('showData1:' + router.getParams()[data]);
  }
}