uniapp中路由的基本使用方法、参数传递方式以及路由拦截与权限控制

ops/2024/11/9 16:44:50/

一、概述
uniapp开发中,路由是非常重要的一个方面,它可以实现页面之间的跳转和传递参数。本文将介绍uniapp中路由的使用技巧,并给出具体的代码示例。

二、uniapp路由的基本使用
uniapp中,路由的基本使用可以通过uni.navigateTo、uni.redirectTo、uni.reLaunch、uni.switchTab等API来进行页面跳转。这些API的使用场景略有不同,具体使用取决于项目需求。

1.uni.navigateTo:用于打开新页面,并保留当前页面。适用于普通的页面跳转。

示例代码:

uni.navigateTo({url: '/pages/detail/detail?id=1'
});

2.uni.redirectTo:用于关闭当前页面,并打开新页面。适用于不需要返回上一页的页面跳转。

示例代码:

uni.redirectTo({url: '/pages/home/home'
});

3.uni.reLaunch:关闭所有页面,打开到应用内的某个页面。适用于从其他平台扫码进入小程序的场景。

示例代码:

uni.reLaunch({url: '/pages/login/login'
});

4.uni.switchTab:跳转到tarBar页面,并关闭其他所有非tarBar页面。适用于底部导航栏页面之间的跳转。

示例代码:

uni.switchTab({url: '/pages/home/home'
});

三、uniapp路由参数的传递
uniapp中,可以通过URL参数的方式来进行页面之间的数据传递。

1.页面之间传递参数在页面A跳转到页面B时,可以通过URL参数来传递数据。在A页面的跳转代码中,通过拼接url的方式传递参数:

uni.navigateTo({url: '/pages/detail/detail?id=' + id
});

2.在B页面中,可以通过uni.$route.query来获取参数值:

onLoad() {console.log(this.$route.query.id);
}

页面返回时传递参数

uniapp中,可以通过uni.navigateBack方法返回上一个页面,并通过调用上一页页面的onBack方法传递参数。具体代码如下:

3.在A页面中,跳转到B页面时,传递参数,并注册上一页页面的onBack方法:

uni.navigateTo({url: '/pages/detail/detail?id=' + id + '&callback=onBack'
});

4.在B页面中,获取参数值,并在页面返回时调用上一页页面的onBack方法传递参数:

methods: {goBack() {uni.navigateBack({delta: 1,success: () => {uni.getOpenerEventChannel().emit(this.asr_notify);}});}
}

5.在A页面中,注册onBack方法并接收参数:

methods: {onBack(data) {console.log(data);}
}

四、uniapp路由拦截与权限控制
在开发过程中,有时候需要对某些页面进行权限控制,以阻止未登录用户访问某些页面。

uniapp中,可以通过导航守卫来实现路由拦截和权限控制。具体代码如下:

1.创建全局路由拦截器,在main.js文件中:

// 全局路由拦截器
router.beforeEach((to, from, next) => {const token = uni.getStorageSync('token');if (to.meta.requiresAuth && !token) { // 判断是否需要登录才能查看页面next('/pages/login/login');} else {next();}
});

2.在需要进行权限控制的页面配置路由元信息:

export default {meta: {requiresAuth: true // 需要登录才能访问}// 省略其他代码...
}

通过以上操作,可以实现对需要登录才能访问的页面进行权限控制,未登录用户将被拦截并跳转到登录页。

总结:
本文介绍了uniapp中路由的基本使用方法、参数传递方式以及路由拦截与权限控制。通过合理的使用路由,可以实现页面之间的跳转和数据传递,提升应用的用户体验。


http://www.ppmy.cn/ops/101087.html

相关文章

python编译器安装包介绍

背景说明 python是一种强大的语言,python的运行需要相关的编译器的支持,随着python的不断更新,存在越来越多的编译器版本,我们通常会去python官网去下载相应的编译器,界面如下,那么图中每一种表示的是什么意…

在网页中实现雪花背景的效果

在网页中实现雪花背景的效果&#xff0c;通常可以通过JavaScript结合HTML和CSS来完成。下面是一个简单的示例&#xff0c;展示了如何使用HTML的<canvas>元素和JavaScript来创建雪花飘落的背景效果。 HTML 首先&#xff0c;在你的HTML文件中添加一个<canvas>元素&…

Oracle RAC 修改系统时区避坑指南(深挖篇)

大家好&#xff0c;这里是 Lucifer三思而后行&#xff0c;专注于提升数据库运维效率。 目录 前言环境安装问题重现时区检查修改时区问题分析问题解决 深究根源问题一问题二问题三 写在最后往期精彩文章推荐 前言 昨天遇到一个问题&#xff0c;Oracle RAC 安装完之后&#xff0…

okhttp的WebSocket心跳实现原理

okhttp的WebSocket实现心跳包需要服务端新增协议吗 ‌不需要。‌ OkHttp的WebSocket实现已经内置了心跳包机制&#xff0c;通过PING/PONG帧来维持连接保活。这意味着&#xff0c;OkHttp的WebSocket客户端和服务端在通信过程中&#xff0c;会自动发送PING/PONG帧来检测连接的活…

redis | 认识非关系数据库Redis的位图数据类型

Redis 非关 kv型 位图常用命令应用场景python操作位图 位图 位图不是真正的数据类型&#xff0c;它是定义在字符串类型中 01100001 97 61 a 01100010 98 62 b 一个字符串类型的值最多能存储512M字节的内容 位上限&#xff1a;2^32 常用命令 SETBIT \x : 16进制 没有key值 GE…

13.JS学习篇-ES6 React 项目模板

1.项目能力支持 1.项目初始化脚手架 1.前端编码规范工程化&#xff08;lint工具、Node CLI等&#xff09; 2.用工具提升项目的编码规范,如&#xff1a;eslint、stylelint、commitlint、markdownlint、husky等 3.工具对于JavaScript、Typescript、React、Vue等不同类型的前端…

Leetcode 77. 组合 组合型回溯 C++实现

Leetcode 77. 组合 问题&#xff1a;给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。你可以按 任何顺序 返回答案。 算法&#xff1a; 创建二维返回数组 ans &#xff0c;和临时数组 path 。 进入 dfs 函数&#xff0c;d 代表还需要选 d 个数字…

【mysql】mysql之数据操作语言(insert、delete、update)

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》&#xff1a;python零基础入门学习 《python运维脚本》&#xff1a; python运维脚本实践 《shell》&#xff1a;shell学习 《terraform》持续更新中&#xff1a;terraform_Aws学习零基础入门到最佳实战 《k8…