網站首頁 編程語言 正文
一、前言
使用antd的tree
組件實現下面這樣的模塊樹,點擊標題請求其下列表的數據,點擊標題旁邊的操作圖標則執行對應的增刪改功能:
二、實現方案
1.封裝一個設置樹標題的方法,通過開關改變state來控制圖標按鈕是否可見:?
處理樹數據(name、children)
const setTree = (module_data: any) => { return module_data.map((item: any) => { let _json = { ...item }; _json.name = setTreeTitle(item); _json.children = item.children ? setTree(item.children) : []; return _json; }); };
賦值給Tree的treeData:
<Tree ... treeData={setTree(treeData)} ... fieldNames={{ title: 'name', key: 'id', children: 'children' }} />
2.樹標題被選中時,則調用刷新列表的方法:
onSelect={(value: any, e: any) => { if (e.selected) { treeSelectFunc(value[0]); } }}
3.但需要注意的坑是,由于我增加了刪除功能,當執行刪除操作后,樹處于選中狀態的話就會報錯,因為處于選中狀態就會調用刷新列表的方法,但該數據已經被我刪除了,可能因此報錯:?
所以我們需要創建一個state來存儲當前選中的數據:
const [selectId, setSelectId] = useState<any>(null);
然后在onSelect
方法中判斷新選中的數據是否是當前數據,如果是則不再執行請求方法:
onSelect={(value: any, e: any) => { const selectValue = value[0] if (e.selected && selectValue !== selectId) { treeSelectFunc(selectValue); setSelectId(selectValue) } }}
這樣就解決了刪除數據可能報錯的問題。
三、總結
原文鏈接:https://juejin.cn/post/7132016113277534216
相關推薦
- 2022-07-29 解決Vmware虛擬機安裝centos8報錯“Section?%Packages?Does?Not?
- 2022-03-15 使用swagger-bootstrap-ui ,訪問的時候 404
- 2022-07-16 MultipartFile與base64互轉
- 2022-04-22 Element UI 表格操作列按鈕顯示不全
- 2022-03-26 C++鏈表節點的添加和刪除介紹_C 語言
- 2022-12-30 Golang反射獲取變量類型和值的方法詳解_Golang
- 2022-06-19 C語言圖文并茂講解分支語句用法_C 語言
- 2022-04-03 C++中的運算符重載詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支