【无标题】

方式: 在外部包一层

利用PermissionControls组件,在这个组件内部进行权限判断处理

	<Route component={Acom}>  
	
	<Route component={(props) => {
						<PermissionControls render={Acom}  {...props}> </PermissionControls>
					}
				}>  

permissionControls组件

	import { useState } from "react"
	function permissionControls() { 
		const [isHasPermission,  setIsHasPermission] = useState(false)
		getPermission() {
			//setIsHasPermission 判断赋值
		}
		return (
			isHasPermission ? 
				<props.render location={props.location}></props.render>
				 : '无权限'
		)
  }
	 

踩坑点

 1. 因为非路由组件, props.location数据不存在, 在用permisssionControls包裹后, 之前的路由组件就不在是路由直接挂载的组件,此时 变为PermissionControls的子组件;
 **所以在权限控制组件的return里, 子组件一定要手动: location = {props.location} 传入**
 2. 动态组件的引入 函数 一定要写传参:  props, 并在 <PermissionControls  {...props}>  传入, 否则在permissionControls组件也获取不到 路由数据
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值