经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » React » 查看文章
React使用高阶组件与Hooks实现权限拦截教程详细分析
来源:jb51  时间:2023/1/30 15:20:05  对本文有异议

高阶组件是以组件作为参数,返回一个组件的函数。返回的组件把传进去的组件进行功能强化。通过以下示例进一步理解高阶组件。

思路

  • 使用HOC包裹需要权限的页面或组件,并注入唯一的权限签名
  • Context保存全局的权限菜单列表,用Provider注入异步获取到的权限菜单
  • HOC中用useContext / Consumer获取权限列表,并和签名做匹配。如果有权限,则展示;没有权限,展示没有权限组件

实现

注入权限列表

抽离Context

在文件中创建一个context,并使用export暴露出对应的Provider,Consumer,Context

  1. /*
  2. * 资源路径 ./src/utils/PermissionContext.js
  3. */
  4. import { createContext } from "react";
  5. const PermissionContext = createContext()
  6. export const PermissionContextProvider = PermissionContext.Provider
  7. export const PermissionContextConsumer = PermissionContext.Consumer
  8. export default PermissionContext

向页面注入权限列表的HOC

此处创建一个HOC,包裹了App组件,实现了向整个页面注入Permission列表

  1. /*
  2. * 资源路径 ./src/components/PermissionIndex/PermissionIndex.js
  3. */
  4. import React, { useState, useEffect } from 'react'
  5. import { PermissionContextProvider } from '../../utils/PermissionContext' // import对应的Context
  6. function PermissionIndex(Component) {
  7. return function Index(props){
  8. const [permission, setpermission] = useState([])
  9. useEffect(()=>{
  10. setpermission(['edituser','checkorder'])
  11. //此处实际为 获取权限列表的请求操作
  12. },[])
  13. //代替了类组件的componenetDidMount生命周期
  14. return (
  15. <PermissionContextProvider value={permission}>
  16. <Component {...props}></Component>
  17. </PermissionContextProvider>
  18. //此处返回了注入权限列表Context的组件
  19. )
  20. }
  21. }
  22. export default PermissionIndex
  • useState用于动态注入获取的权限列表
  • 组件通过Context.Provider包裹。权限列表改变,所有消费权限列表的组件重新更新

向根组件注入权限

  1. import React from 'react';
  2. import ReactDOM from 'react-dom';
  3. import './index.css';
  4. import App from './pages/App/App'
  5. import PermissionIndex from './components/PermissionIndex/PermissionIndex'
  6. const IndexWithPermission = PermissionIndex(App)
  7. ReactDOM.render(
  8. <IndexWithPermission/>,
  9. document.getElementById('root')
  10. );

含有权限拦截功能的HOC

无权限时显示的组件

  1. import React from 'react'
  2. function NoPermission() {
  3. return (
  4. <div>对不起,请与管理员获取权限</div>
  5. )
  6. }
  7. export default NoPermission

权限拦截HOC组件

  1. /*
  2. * 资源路径 ./src/components/PermissionHOC/PermissionHOC.js
  3. */
  4. import React, { useContext } from 'react'
  5. import PermissionContext from '../../utils/PermissionContext'
  6. import NoPermission from '../NoPermission/NoPermission'
  7. function PermissionHoc(authorization) {
  8. return function(Component){
  9. return function PermissionIndex(props){
  10. const context = useContext(PermissionContext)
  11. //使用useContext获取当前的权限列表,相当于类组件中的contentType静态属性
  12. return context.indexOf(authorization) >= 0 ? <Component {...props}></Component> : <NoPermission></NoPermission>
  13. }
  14. }
  15. }
  16. export default PermissionHoc
  • 此示例中使用两层包装函数的HOC,第一层用于获取HOC绑定的当前组件的权限签名,因为要用这个权限签名和权限列表做匹配。第二层接受原始组件。
  • 在HOC中使用 useContext 接收权限列表,做权限匹配。组件有权限则展示,没有权限则展示无权限组件。

测试

用于测试的组件

  1. /*
  2. * 资源路径 ./src/components/PermissionTest/PermissionTest.js
  3. */
  4. import React from 'react'
  5. function PermissionTest(props) {
  6. return (
  7. <div>PermissionTest - {props?.name}</div>
  8. )
  9. }
  10. export default PermissionTest

在组件中使用权限组件

  1. /*
  2. * 资源路径 ./src/components/App/App.js
  3. */
  4. import React, { useContext, useEffect, useRef } from 'react'
  5. import PermissionContext from '../../utils/PermissionContext'
  6. import PermissionHoc from '../../components/PermissionHoc/PermissionHoc'
  7. import PermissionTest from '../../components/PermissionTest/PermissionTest'
  8. export default function App() {
  9. const Edituser = PermissionHoc('edituser')(PermissionTest)
  10. const Edituser1 = PermissionHoc('edituser1')(PermissionTest)
  11. return (
  12. <div>
  13. <Edituser name="edituser"></Edituser>
  14. <Edituser1 name="edituser1"></Edituser1>
  15. </div>
  16. )
  17. }

此处,通过用PermissionHOC函数处理原始组件,进行了权限拦截功能

到此这篇关于React使用高阶组件与Hooks实现权限拦截教程详细分析的文章就介绍到这了,更多相关React权限拦截内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号