網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
高階組件是以組件作為參數(shù),返回一個(gè)組件的函數(shù)。返回的組件把傳進(jìn)去的組件進(jìn)行功能強(qiáng)化。通過(guò)以下示例進(jìn)一步理解高階組件。
思路
- 使用
HOC
包裹需要權(quán)限的頁(yè)面或組件,并注入唯一的權(quán)限簽名 - 用
Context
保存全局的權(quán)限菜單列表,用Provider
注入異步獲取到的權(quán)限菜單 - 在
HOC
中用useContext / Consumer
獲取權(quán)限列表,并和簽名做匹配。如果有權(quán)限,則展示;沒(méi)有權(quán)限,展示沒(méi)有權(quán)限組件
實(shí)現(xiàn)
注入權(quán)限列表
抽離Context
在文件中創(chuàng)建一個(gè)context
,并使用export
暴露出對(duì)應(yīng)的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
向頁(yè)面注入權(quán)限列表的HOC
此處創(chuàng)建一個(gè)HOC
,包裹了App組件,實(shí)現(xiàn)了向整個(gè)頁(yè)面注入Permission列表
/* * 資源路徑 ./src/components/PermissionIndex/PermissionIndex.js */ import React, { useState, useEffect } from 'react' import { PermissionContextProvider } from '../../utils/PermissionContext' // import對(duì)應(yīng)的Context function PermissionIndex(Component) { return function Index(props){ const [permission, setpermission] = useState([]) useEffect(()=>{ setpermission(['edituser','checkorder']) //此處實(shí)際為 獲取權(quán)限列表的請(qǐng)求操作 },[]) //代替了類組件的componenetDidMount生命周期 return ( <PermissionContextProvider value={permission}> <Component {...props}></Component> </PermissionContextProvider> //此處返回了注入權(quán)限列表Context的組件 ) } } export default PermissionIndex
-
useState
用于動(dòng)態(tài)注入獲取的權(quán)限列表 - 組件通過(guò)
Context.Provider
包裹。權(quán)限列表改變,所有消費(fèi)權(quán)限列表的組件重新更新
向根組件注入權(quán)限
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( <IndexWithPermission/>, document.getElementById('root') );
含有權(quán)限攔截功能的HOC
無(wú)權(quán)限時(shí)顯示的組件
import React from 'react' function NoPermission() { return ( <div>對(duì)不起,請(qǐng)與管理員獲取權(quán)限</div> ) } export default NoPermission
權(quán)限攔截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獲取當(dāng)前的權(quán)限列表,相當(dāng)于類組件中的contentType靜態(tài)屬性 return context.indexOf(authorization) >= 0 ? <Component {...props}></Component> : <NoPermission></NoPermission> } } } export default PermissionHoc
- 此示例中使用兩層包裝函數(shù)的HOC,第一層用于獲取HOC綁定的當(dāng)前組件的權(quán)限簽名,因?yàn)橐眠@個(gè)權(quán)限簽名和權(quán)限列表做匹配。第二層接受原始組件。
- 在HOC中使用
useContext
接收權(quán)限列表,做權(quán)限匹配。組件有權(quán)限則展示,沒(méi)有權(quán)限則展示無(wú)權(quán)限組件。
測(cè)試
用于測(cè)試的組件
/* * 資源路徑 ./src/components/PermissionTest/PermissionTest.js */ import React from 'react' function PermissionTest(props) { return ( <div>PermissionTest - {props?.name}</div> ) } export default PermissionTest
在組件中使用權(quán)限組件
/* * 資源路徑 ./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 ( <div> <Edituser name="edituser"></Edituser> <Edituser1 name="edituser1"></Edituser1> </div> ) }
此處,通過(guò)用PermissionHOC
函數(shù)處理原始組件,進(jìn)行了權(quán)限攔截功能
原文鏈接:https://blog.csdn.net/m0_52761633/article/details/123493935
相關(guān)推薦
- 2022-06-25 C++文件讀寫操作詳解_C 語(yǔ)言
- 2022-06-11 利用Nginx實(shí)現(xiàn)URL重定向的簡(jiǎn)單方法_nginx
- 2022-12-05 C語(yǔ)言實(shí)現(xiàn)順序表的基本操作的示例詳解_C 語(yǔ)言
- 2023-01-21 python中封裝token問(wèn)題_python
- 2022-10-25 maven方式創(chuàng)建spring項(xiàng)目-eclipse篇
- 2022-07-24 Git版本控制服務(wù)器詳解_其它綜合
- 2022-07-10 axios調(diào)用接口報(bào)錯(cuò)
- 2023-06-17 C#中Stopwatch的使用及說(shuō)明_C#教程
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支