欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

react 權(quán)限樹形結(jié)構(gòu)實(shí)現(xiàn)代碼

 更新時(shí)間:2024年05月27日 14:58:59   作者:huoyueyi  
這篇文章主要介紹了react 權(quán)限樹形結(jié)構(gòu)實(shí)現(xiàn)代碼,項(xiàng)目背景react + ant design,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧

項(xiàng)目背景 react + ant design

實(shí)現(xiàn)效果

1 將后臺(tái)返回的平鋪數(shù)據(jù) , 轉(zhuǎn)成樹形結(jié)構(gòu)

 const [roleId, setRoleId] = useState('') //存儲(chǔ)角色id
  // 彈權(quán)限彈窗
  const empowerHandle = async record => {
    setRoleId(record.roleId)
    //獲取單獨(dú)的權(quán)限
    const res1 = await getPermission({ roleId: record.roleId })
    console.log('res1', res1)
    const res2 = await getSimple()
    console.log('res2', res2)
    //平鋪數(shù)據(jù)轉(zhuǎn)樹形結(jié)構(gòu)
    function buildTree (data, parentId = 0) {
      let tree = [] // 用于存放結(jié)果的數(shù)組
      // 遍歷數(shù)據(jù),找到parentId匹配的項(xiàng)
      for (let item of data) {
        if (item.parentId === parentId) {
          // 創(chuàng)建一個(gè)新對象,準(zhǔn)備添加子節(jié)點(diǎn)
          let node = { ...item, children: buildTree(data, item.permissionId) } // 遞歸調(diào)用,處理子節(jié)點(diǎn)
          tree.push(node) // 將當(dāng)前節(jié)點(diǎn)添加到結(jié)果數(shù)組中
        }
      }
      return tree
    }
    // title替換permissionName,讓樹形結(jié)構(gòu)內(nèi)容可以展示出來
    const res3 = res2.map(item => {
      return {
        ...item,
        title: item.permissionName,
        key: item.permissionId
      }
    })
    const result1 = buildTree(res1, 0) // 獲取單獨(dú)的權(quán)限
    console.log('res1111111', result1)
    // 獲取res1中的permissionId作為已選中的Id列表
    const selectedIds = res1.map(item => item.permissionId)
    console.log('selectedIds', selectedIds)
    // 構(gòu)建treeData時(shí)同時(shí)處理選中狀態(tài)
    const result = buildTree(res3, 0)
    console.log('3333333333333', result)
    setTreeData(result)
    setcheckedKeys(selectedIds)
    setempower(true)
  }

2 拿到角色id并傳遞到tree中

  // 獲取選中的權(quán)限,為了修改權(quán)限
  const ontreeCheck = checkedKeysValue => {
    console.log('onCheck', checkedKeysValue.checked) // 這里可以拿到選中的所有的權(quán)限id
    setcheckedKeys(checkedKeysValue.checked)
  }
  // 修改權(quán)限提交
  const treesubmit = async () => {
    const res1 = await getEditPermission({
      roleId: roleId,
      permissionIds: checkedKeys
    })
    setempower(false)
  }
    <Tree
                checkable
                checkedKeys={checkedKeys}
                defaultExpandAll={false} //讓授權(quán)后的彈窗只展示根標(biāo)簽
                treeData={treeData}
                // multiple // 支持多選。當(dāng)父子不關(guān)聯(lián),添加后,點(diǎn)擊父,不能控制所有子
                // showLine //刪除這里,樹形結(jié)構(gòu)左側(cè)的下拉線消失,圖標(biāo)從+-更改為默認(rèn)的△
                checkStrictly // 開啟后,父子節(jié)點(diǎn)不關(guān)聯(lián)(子空一個(gè),父就空)
                onCheck={ontreeCheck}
              />
  const [treeData, setTreeData] = useState([
    {
      title: '0-1',
      key: '0-1',
      children: [
        {
          title: '0-1-0-0',
          key: '0-1-0-0'
        },
        {
          title: '0-1-0-1',
          key: '0-1-0-1'
        },
        {
          title: '0-1-0-2',
          key: '0-1-0-2'
        }
      ]
    },
    {
      title: '0-2',
      key: '0-2'
    }
  ])

到此這篇關(guān)于react 權(quán)限樹形結(jié)構(gòu)實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)react 權(quán)限樹形結(jié)構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React中進(jìn)行條件渲染的實(shí)現(xiàn)方法

    React中進(jìn)行條件渲染的實(shí)現(xiàn)方法

    React是一種流行的JavaScript庫,它被廣泛應(yīng)用于構(gòu)建Web應(yīng)用程序,在React中,條件渲染是一個(gè)非常重要的概念,它允許我們根據(jù)不同的條件來呈現(xiàn)不同的內(nèi)容,在本文中,我們將探討React如何進(jìn)行條件渲染,需要的朋友可以參考下
    2023-11-11
  • React技巧之中斷map循環(huán)的方法詳解

    React技巧之中斷map循環(huán)的方法詳解

    這篇文章主要和大家來分享一下React的技巧之如何中斷map循環(huán),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下
    2023-06-06
  • React事件處理和表單的綁定詳解

    React事件處理和表單的綁定詳解

    這篇文章主要介紹了React事件處理和表單的綁定,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Remix后臺(tái)開發(fā)之remix-antd-admin配置過程

    Remix后臺(tái)開發(fā)之remix-antd-admin配置過程

    這篇文章主要為大家介紹了Remix后臺(tái)開發(fā)之remix-antd-admin配置過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • React?Hooks鉤子中API的使用示例分析

    React?Hooks鉤子中API的使用示例分析

    在react類組件(class)寫法中,有setState和生命周期對狀態(tài)進(jìn)行管理,但是在函數(shù)組件中不存在這些,故引入hooks(版本:>=16.8),使開發(fā)者在非class的情況下使用更多react特性
    2022-08-08
  • React Fiber樹的構(gòu)建和替換過程講解

    React Fiber樹的構(gòu)建和替換過程講解

    React Fiber樹的創(chuàng)建和替換過程運(yùn)用了雙緩存技術(shù),直接將舊的 fiber 樹替換成新的 fiber 樹,這樣做的好處是省去了直接在頁面上渲染時(shí)的計(jì)算時(shí)間,避免計(jì)算量大導(dǎo)致的白屏、卡頓,現(xiàn)在你一定還不太理解,下面進(jìn)行詳細(xì)講解,需要的朋友可以參考下
    2022-12-12
  • 使用React18和WebSocket構(gòu)建實(shí)時(shí)通信功能詳解

    使用React18和WebSocket構(gòu)建實(shí)時(shí)通信功能詳解

    WebSocket是一種在Web應(yīng)用中實(shí)現(xiàn)雙向通信的協(xié)議,它允許服務(wù)器主動(dòng)向客戶端推送數(shù)據(jù),而不需要客戶端發(fā)起請求,本文將探索如何在React?18應(yīng)用中使用WebSocket來實(shí)現(xiàn)實(shí)時(shí)通信,感興趣的可以了解下
    2024-01-01
  • React組件的應(yīng)用介紹

    React組件的應(yīng)用介紹

    React組件分為函數(shù)組件與class組件;函數(shù)組件是無狀態(tài)組件,class稱為類組件;函數(shù)組件只有props,沒有自己的私有數(shù)據(jù)和生命周期函數(shù);class組件有自己私有數(shù)據(jù)(this.state) 和 生命周期函數(shù)
    2022-09-09
  • react如何同步獲取useState的最新狀態(tài)值

    react如何同步獲取useState的最新狀態(tài)值

    這篇文章主要介紹了react如何同步獲取useState的最新狀態(tài)值問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • React中的Component組件詳解

    React中的Component組件詳解

    本章節(jié),我們將一起探討 React 中類組件和函數(shù)組件的定義,不同組件的通信方式,以及常規(guī)組件的強(qiáng)化方式,幫助你全方位認(rèn)識(shí) React 組件,從而對 React 的底層邏輯有進(jìn)一步的理解,感興趣的朋友跟隨小編一起看看吧
    2023-06-06

最新評論