1. 路由技术 ( 详细记录 )

是笔记不是博文,觉得写的不够详细的可以使用Ctrl + W组合键

路由跳转页面

1. HTML 中使用 routerLink 属性路由进行跳转,传值时使用 queryParams 属性

<ion-item routerLink="/info1" [queryParams]="{name: '张'}">
<ion-label>页面跳转</ion-label>
</ion-item>

2.1 通过 router 实现编程式导航以及携带参数 ( 官方推荐 ):

export class Tab1Page {
constructor(public router: Router) {}
openInfo1(){
this.router.navigate(["info1"], {
queryParams: {name: "张"}
})
}
}

2.2 通过 router 实现编程式导航以及携带参数:

export class Tab1Page {
constructor(public router: Router) {}
openInfo2(){
this.router.navigate(["info1", {name: "张"}])
}
}

3. 通过 NavController 实现编程式导航以及携带参数:

export class Tab1Page {
constructor(public navCtrl: NavController) {}
openInfo3(){
this.navCtrl.navigateForward("info1", {
queryParams: { name: "张" }
})
}
}

返回到上一页面

1. HTML 中进行返回,slot 属性为 start 时按钮在左侧,end 则在右侧

<ion-header>
<ion-toolbar>
<!-- slot="end" -->
<ion-buttons slot="start">
<ion-back-button></ion-back-button>
</ion-buttons>
<ion-title>info1</ion-title>
</ion-toolbar>
</ion-header>

2. 通过 router 编程式导航进行返回

export class Info1Page {
constructor(public router: Router) { }
back(){
/*
* 返回到指定页面,严格点说是基于返回的动画执行的打开页面的操作
* 例如我从info1打开info2,从info2中使用router.navigateByUrl返回到info1
* 正常的返回什么都不会发生,但是这种会重新触发info1的生命周期函数
*/
this.router.navigateByUrl("/tabs/tab1");
}
}

3.1 通过 navController 编程式导航进行返回

export class Info1Page {
constructor(public navCtrl: NavController) { }
openInfo2(){
this.navCtrl.navigateForward("info2")
}
back(){
/*
* 这种返回是基于路径的历史记录进行返回的,他在后退的时候回根据上一个打开的页面进行返回
*
* 例如打开info1,然后打开info2,info2使用router.navigateByUrl进行返回,由于
* router.navigateByUrl是基于返回的动画执行的打开操作,所以info1使用nav.back进行
* 返回的时候就会进入死循环,而且由于打开顺序的问题,动画也会被改变
*/
this.navCtrl.back();
}
}

3.2 通过 navController 编程式导航进行返回

export class Info1Page {
constructor(public navCtrl: NavController) { }
openInfo2(){
this.navCtrl.navigateForward("info2")
}
back(){
/*
* pop不同于之前的函数,他是基于路由层级进行后退而不是基于历史记录进行后退
* 可以说从根本上就可以解决 3.1 中出现的死循环问题
*/
this.navCtrl.pop();
}
}

接收路由传参

路由的跳转 ( 打开以及返回 ) 基本已经掌握了,接下来开始学习获取路由传参的四种方法,路由传参的方法有很多种,不同的传参方式,接收的方法也不太相同,不过他们有一个共同点:使用的都是 ActivatedRoute

1.1 获取路由传参的第一种方式

export class Info1Page {
constructor(public navCtrl: NavController, public navParam: ActivatedRoute) {
navParam.queryParams.subscribe( param=>{
console.log(param);
})
console.log("取值完毕!");
}
}

这种方式是在 queryParams 中获取路由携带参数,适用于之前提到路由传参的【1】【2.1】【3】位置,但是这种获取方式有一个问题,subscribe 是异步的,也就是说 log("取值完毕!") 的执行会优先于 log( param ),这样在获取值后的操作就会显得没有那么方便

1.2 获取路由传参的第一种方式 ( 同步 )

想要同步取值也不难,只需要改变一下代码:

export class Info1Page {
constructor(public navCtrl: NavController, public navParam: ActivatedRoute) {
// 通过 snapshot 就可以实现同步获取
console.log(navParam.snapshot.queryParams);
console.log("取值完毕!");
}
}

2.1 获取路由传参的第二种方式

export class Info1Page {
constructor(public navCtrl: NavController, public navParam: ActivatedRoute) {
navParam.params.subscribe( param=>{
console.log(param);
})
console.log("取值完毕!");
}
}

params 中也可以获取路由携带参数,适用于之前提到路由传参的【2.2】位置,同样这种获取方式还存在异步问题,获取值后的操作也没那么方便,解决方案也是一样的

2.2 获取路由传参的第二种方式 ( 同步 )

export class Info1Page {
constructor(public navCtrl: NavController, public navParam: ActivatedRoute) {
// 通过 snapshot 就可以实现同步获取
console.log(navParam.snapshot.params);
console.log("取值完毕!");
}
}

实现页面重复打开

当我们在列表页打开一个详细信息页面的时候,一般会传递一个 ID 在详细信息页面进行查询,如果我们在详细信息页面同样还要打开一个详细信息页面时,路由重复,这样页面就不会有任何操作,这里推荐的解决方案是一种新的传值方式

例如我要重复打开 info1 页面:

1. 首先在路由上动手脚:app-routing.module

const routes: Routes = [
{
path: '',
loadChildren: () => import('./tabs/tabs.module').......省略
},
{
path: 'info1',
loadChildren: () => import('./info1/info1.module').......省略
},
// 新增这样一个路由,代表接收变量名为time的值,以/的方式进行传值
{
path: 'info1/:time',
loadChildren: () => import('./info1/info1.module').......省略
}
];

2. 然后在需要重复打开的页面中修改访问路径

export class Info1Page {
constructor(public navCtrl: NavController) { }
openInfo1(){
// 在访问路径后面拼【接斜线+毫秒值】,使用毫秒值的原因就是防止值重复
this.navCtrl.navigateForward("info1/" + new Date().getTime());
}
}

最终访问的路径就变成了: http://localhost:4200/info1/1601452910158,可以解决重复访问问题

上面的 1601452910158 毫秒值代表的就是 time 变量对应的值,这也属于路由传值的一种,如果想要在页面上获取到这串毫秒值可以使用路由接收传参的【2.1】或【2.2】

Ionic5路由跳转传值复用的更多相关文章

  1. ionic4 路由跳转、ionic4 路由跳转传值 NavController 返回上一页 、NavController 回到根

    1.普通路由跳转 <ion-button [routerLink]="['/pinfo']"> 跳转到详情 </ion-button> <ion-he ...

  2. 16Flutter中的路由 基本路由 基本路由跳转传值(上)

    /* Flutter中的普通路由.普通路由传值.命名路由.命名路由传值 Flutter中的路由通俗的讲就是页面跳转.在Flutter中通过Navigator组件管理路由导航. 并提供了管理堆栈的方法. ...

  3. Angular配置路由以及动态路由取值传值跳转

    Angular配置路由 1.找到 app-routing.module.ts 配置路由 引入组件 import { HomeComponent } from './home/home.componen ...

  4. angular中路由跳转并传值四种方式

    一.路由传值 步骤1 路由传递参数 注意 一定是要传递 索引值 let key = index 这种情况是在浏览器中可以显示对应的参数 这种的是问号 localhost:8080/news?id=2& ...

  5. 路由传值及获取参数,路由跳转,路由检测,this.$route.query和this.$route.params接收参数,HttpGet请求拼接url参数

    配置动态路由参数id: routes: [ // 动态路径参数 以冒号开头 { path: '/user/:id', component: User } ] html路由跳转: <router- ...

  6. vue当前路由跳转初步研究

    一样闲话少说,直接上问题,如图: 也是消息面板,没想到一个小小的消息面板,碰到这么多坑,惆怅. 就是如果当前路由和跳转路由不一样时,正常跳转没有任何问题.但是如果一样时,就不会跳转了,用了很多方法,比 ...

  7. Reactjs之静态路由、动态路由以及Get传值以及获取

    1.新增知识点 /* react路由的配置: 1.找到官方文档 https://reacttraining.com/react-router/web/example/basic 2.安装 cnpm i ...

  8. vue根据参数不同的路由跳转以及name的作用

    最近在做VUE路由跳转根据参数的值不同但是跳转的是同一个路由的功能.点击左边的目录,根据目录ID跳转不同的列表.如下图. 路由跳转的代码: this.$router.push({path: '/RFI ...

  9. vue常用操作及学习笔记(路由跳转及路由传参篇)

    路由跳转 - 超链接方式跳转 html: <div id="app"> <h1>Hello App!</h1> <p> <!- ...

随机推荐

  1. Git:使用远程仓库

    远程仓库可使用Github.Gitee,或自建Gitlab.Gogs服务器,这里使用Github. 配置本地用户名和邮箱 # 配置本地用户的用户名邮箱(保存在用户.gitconfig文件) $ git ...

  2. 一文帮你搞懂 Android 文件描述符

    介绍文件描述符的概念以及工作原理,并通过源码了解 Android 中常见的 FD 泄漏. 一.什么是文件描述符? 文件描述符是在 Linux 文件系统的被使用,由于Android基 于Linux 系统 ...

  3. 小程序setData中key用变量

    Page({ data:{ //类型列表 lastRootList:0,//上次点击的类型 rootList:[{name:'服饰箱包',selectClass:'root-active',iconC ...

  4. 字符串匹配-BF算法和KMP算法

    声明:图片及内容基于https://www.bilibili.com/video/av95949609 BF算法 原理分析 Brute Force 暴力算法 用来在主串中查找模式串是否存以及出现位置 ...

  5. ES6学习笔记(1)- 块级作用域

    1. var声明变量和变量提升(Hoisting)机制的问题 在JS中通过var关键字声明的变量,无论在函数作用域中亦或是全局作用域中,都会被当成当前作用域顶部的变量,和就是所谓的提升机制(Hoist ...

  6. Hive相关的命令

    hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供完整的sql查询功能,可以将sql语句转换为MapReduce任务进行运行. 其优点是学习成本低,可以通过 ...

  7. 初见pyecharts

    pyecharts(可互动的可视化) 模块准备 在Anaconda Prompt中下载pyecharts v1版本(>=python3.6) pip install pyecharts 可视化最 ...

  8. PTA 数组元素的区间删除

    6-6 数组元素的区间删除 (20 分)   给定一个顺序存储的线性表,请设计一个函数删除所有值大于min而且小于max的元素.删除后表中剩余元素保持顺序存储,并且相对位置不能改变. 函数接口定义: ...

  9. 在SSM框架中如何将图片上传到数据库中

    今天我们来看看SSM中如何将图片转换成二进制,最后传入到自己的数据库中,好了,废话不多说,我们开始今天的学习,我这里用的编辑器是IDEA 1.导入图片上传需要的jar依赖包 1 <depende ...

  10. springMVC:校验框架:多规则校验,嵌套校验,分组校验;ssm整合技术

    知识点梳理 课堂讲义 学习目标 能够阐述表单验证的分类和区别 能够运用表单验证的常用注解 能够编写表单验证的示例 能够编写SSM整合的应用案例 能够总结SSM整合的步骤 1 校验框架 1.1 入门-视 ...