uniapp中实现路由拦截

核心:

const whiteList=[
	'/pages/index/index',
	'/pages/login/login'
]
const loginPage="/pages/login/login";
export  function initPermission(){
	console.log("initPermission:",)
	const routeFnList=["navigateTo","redirectTo","reLaunch","switchTab"]
	routeFnList.forEach(item=>{
		uni.addInterceptor(item,{
			invoke(e){
				console.log("invoke:")
				const token=uni.getStorageInfoSync("token");
				const url=e.url.split("?")[0];
				console.log("url:",url)
				let notNeed=whiteList.includes(url)
				if(notNeed){
					return e
				}else{
					console.log("token:",token)
					if(token.keys.length==0){
						uni.showToast({
							title:"请登录",
							icon:"none"
						})
						uni.navigateTo({
							url:loginPage
						})
						return false
					}else{
						return e
					}
				}
			},
			success(res){
				console.log("invoke-success",res)
			},
			fail(err){
				console.log("err",err)
			}	
		})		
	})
	
}

第二步:在app.vue中的onlaunch调用该函数

import {initPermission} from "./permission.js"
	export default {
		onLaunch: function() {
			console.log('App Launch')
			initPermission()
		},
		
	}

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值