91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React如何使用高階組件與Hooks實現權限攔截

發布時間:2023-01-30 09:11:10 來源:億速云 閱讀:173 作者:iii 欄目:開發技術

本篇內容主要講解“React如何使用高階組件與Hooks實現權限攔截”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“React如何使用高階組件與Hooks實現權限攔截”吧!

高階組件是以組件作為參數,返回一個組件的函數。返回的組件把傳進去的組件進行功能強化。通過以下示例進一步理解高階組件。

思路

  • 使用HOC包裹需要權限的頁面或組件,并注入唯一的權限簽名

  • Context保存全局的權限菜單列表,用Provider注入異步獲取到的權限菜單

  • HOC中用useContext / Consumer獲取權限列表,并和簽名做匹配。如果有權限,則展示;沒有權限,展示沒有權限組件

實現

注入權限列表

抽離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 (
      <PermissionContextProvider value={permission}>
        <Component {...props}></Component>
      </PermissionContextProvider>
      //此處返回了注入權限列表Context的組件
    )
  }
}
export default PermissionIndex
  • useState用于動態注入獲取的權限列表

  • 組件通過Context.Provider包裹。權限列表改變,所有消費權限列表的組件重新更新

向根組件注入權限
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')
);

含有權限攔截功能的HOC

無權限時顯示的組件
import React from 'react'
function NoPermission() {
  return (
    <div>對不起,請與管理員獲取權限</div>
  )
}
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 ? <Component {...props}></Component> : <NoPermission></NoPermission>
    }
  }
}
export default PermissionHoc
  • 此示例中使用兩層包裝函數的HOC,第一層用于獲取HOC綁定的當前組件的權限簽名,因為要用這個權限簽名和權限列表做匹配。第二層接受原始組件。

  • 在HOC中使用 useContext 接收權限列表,做權限匹配。組件有權限則展示,沒有權限則展示無權限組件。

測試

用于測試的組件
/*
 * 資源路徑 ./src/components/PermissionTest/PermissionTest.js
 */
import React from 'react'
function PermissionTest(props) {
  return (
    <div>PermissionTest - {props?.name}</div>
  )
}
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 (
    <div>
        <Edituser name="edituser"></Edituser>
        <Edituser1 name="edituser1"></Edituser1>
    </div>
  )
}

此處,通過用PermissionHOC函數處理原始組件,進行了權限攔截功能

React如何使用高階組件與Hooks實現權限攔截

到此,相信大家對“React如何使用高階組件與Hooks實現權限攔截”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

丹寨县| 什邡市| 崇阳县| 赤峰市| 南涧| 枣阳市| 淳安县| 玛曲县| 汉寿县| 苍南县| 米林县| 西峡县| 集贤县| 家居| 荔浦县| 青田县| 赤峰市| 即墨市| 辽宁省| 旬邑县| 徐水县| 杭州市| 永顺县| 色达县| 新疆| 莒南县| 孝昌县| 奎屯市| 津南区| 义马市| 北安市| 尤溪县| 旌德县| 昌图县| 抚顺市| 花莲县| 香格里拉县| 称多县| 新竹市| 龙门县| 手游|