高阶组件是以组件作为参数,返回一个组件的函数。返回的组件把传进去的组件进行功能强化。通过以下示例进一步理解高阶组件。
思路
实现
注入权限列表
抽离Context
在文件中创建一个context,并使用export暴露出对应的Provider,Consumer,Context
/* * 资源路径 ./src/utils/PermissionContext.js */ import { createContext } from "react"; const PermissionContext = createContext() export const PermissionContextProvider = PermissionContext.Provider export const PermissionContextConsumer = PermissionContext.Consumer export default PermissionContext
向页面注入权限列表的HOC
此处创建一个HOC,包裹了App组件,实现了向整个页面注入Permission列表
/* * 资源路径 ./src/components/PermissionIndex/PermissionIndex.js */ import React, { useState, useEffect } from 'react' import { PermissionContextProvider } from '../../utils/PermissionContext' // import对应的Context function PermissionIndex(Component) { return function Index(props){ const [permission, setpermission] = useState([]) useEffect(()=>{ setpermission(['edituser','checkorder']) //此处实际为 获取权限列表的请求操作 },[]) //代替了类组件的componenetDidMount生命周期 return ( //此处返回了注入权限列表Context的组件 ) } } export default PermissionIndex
向根组件注入权限
import React from 'react'; import ReactDOM from 'react-dom'; import './index.css'; import App from './pages/App/App' import PermissionIndex from './components/PermissionIndex/PermissionIndex' const IndexWithPermission = PermissionIndex(App) ReactDOM.render( , document.getElementById('root') );
含有权限拦截功能的HOC
无权限时显示的组件
import React from 'react' function NoPermission() { return ( 对不起,请与管理员获取权限 ) } export default NoPermission
权限拦截HOC组件
/* * 资源路径 ./src/components/PermissionHOC/PermissionHOC.js */ import React, { useContext } from 'react' import PermissionContext from '../../utils/PermissionContext' import NoPermission from '../NoPermission/NoPermission' function PermissionHoc(authorization) { return function(Component){ return function PermissionIndex(props){ const context = useContext(PermissionContext) //使用useContext获取当前的权限列表,相当于类组件中的contentType静态属性 return context.indexOf(authorization) >= 0 ? : } } } export default PermissionHoc
测试
用于测试的组件
/* * 资源路径 ./src/components/PermissionTest/PermissionTest.js */ import React from 'react' function PermissionTest(props) { return ( PermissionTest - {props?.name} ) } export default PermissionTest
在组件中使用权限组件
/* * 资源路径 ./src/components/App/App.js */ import React, { useContext, useEffect, useRef } from 'react' import PermissionContext from '../../utils/PermissionContext' import PermissionHoc from '../../components/PermissionHoc/PermissionHoc' import PermissionTest from '../../components/PermissionTest/PermissionTest' export default function App() { const Edituser = PermissionHoc('edituser')(PermissionTest) const Edituser1 = PermissionHoc('edituser1')(PermissionTest) return ( ) }
此处,通过用PermissionHOC函数处理原始组件,进行了权限拦截功能
到此这篇关于React使用高阶组件与Hooks实现权限拦截教程详细分析的文章就介绍到这了
我的微信
微信号已复制
我的微信
这是我的微信扫一扫