React實踐之Tree組件的使用方法
更新時間:2017年09月30日 14:40:12 作者:oylp
本篇文章主要介紹了React實踐之Tree組件的使用方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
本文介紹了React實踐之Tree組件,分享給大家,具體如下:
實現(xiàn)功能
- 渲染數(shù)據(jù)
- 展開合并
使用
數(shù)據(jù)結構:
const node = { title: '00000', key: '0' , level:'level1', open: true, child:[ { title: '0-111111', key: '0-0', level:'level2', open: true, child:[ { title: '0-1-1111', key: '0-0-0', level:'level3', }, { title: '0-1-2222', key: '0-0-1', level:'level3', open: true, child: [ { title: '0-1-2-11111', key: '0-0-1-0', level:'level4', open: true, child: [ { title: '0-1-2-1-111', key: '0-0-1-0-0', level:'level5', } ] } ] }, { title: '0-1-33333', key: '0-0-4', level:'level3', }, ] }, { title: '0-222222', key: '0-2', level:'level2', open: false, child: [ { title: '0-2-1111', key: '0-2-0', level:'level3', }, { title: '0-2-22222', key: '0-2-1', level:'level3', }, { title: '0-2-33333', key: '0-2-2', level:'level3', } ] } ] }
引用代碼:
<div> <Tree treeList = {node} /> </div>
組件實現(xiàn)代碼:
import React, { Component } from 'react'; import classNames from 'classnames'; const history = createHistory(); import { BrowserRouter as Router, HashRouter, Route, Link, Switch, NavLink } from 'react-router-dom'; class Tree extends Component { constructor(props){ super(props) this.treeItemCroup = this.treeItemCroup.bind(this); this.handleClick = this.handleClick.bind(this); this.state ={ openList : false } } handleClick(e) { // 這是點擊➡️ 時調用的方法 // 如果當前這個➡️ 沒有旋轉,那就設置旋轉,視覺效果 e.target.style.transform = e.target.style.transform == "rotate(-90deg)" ? "rotate(0deg)" : "rotate(-90deg)" for(let item in e.target.parentNode.parentNode.childNodes){ // 點擊的時候設置當前層級的子元素素隱藏 // 操作了DOM,我很難受 if(item > 0){ e.target.parentNode.parentNode.childNodes[item].style.display = e.target.parentNode.parentNode.childNodes[item].style.display === 'none' ? 'block' : 'none' } } } itemTitle(item){ // 這個是返回title,因為有時候是點擊一個鏈接,所以設置了兩種情況,如果node節(jié)點里面有component這個節(jié)點,那就設置成可以點擊跳轉 if(item.component){ return (<Link to={ item.component } > <span onClick={this.handleClick.bind(this)}>{item.title}</span> </Link>) }else{ return ( <span onClick={this.handleClick.bind(this)}>{item.title}</span> ) } } treeItemCroup(itemGroup) { let itemGroupItem = [] // 每個元素的樣式,根據(jù)當前等級來設置樣式,level1的就縮緊20px,level2的縮緊40px,一次類推,在視覺上呈現(xiàn)樹的形式 let itemStyle = { paddingLeft: 20*parseInt(itemGroup.level.slice(5), 10)+'px' } // 如果當前節(jié)點還有子元素,就設置一個➡️ 箭頭 ,可以點擊展開。 let iconChevron = classNames('fa',{'fa-chevron-down' : itemGroup.child}) // 把所有節(jié)點放在一個數(shù)組里面 itemGroupItem.push( <ul> {/* 第一個層級 */} <li className={itemGroup.level} key={itemGroup.key} style={itemStyle}> <i aria-hidden="true" className={iconChevron} onClick={this.handleClick.bind(this)}></i> {this.itemTitle(itemGroup)} </li> {/* 調用tree方法 */} {this.tree(itemGroup.child)} </ul> ) return itemGroupItem } tree(child){ let treeItem // 如果有子元素 if(child){ // 子元素是數(shù)組的形式,把所有的子元素循環(huán)出來 treeItem = child.map((item, key) => { // 同理,設置樣式 let itemStyle = { paddingLeft: 20*parseInt(item.level.slice(5), 10)+'px' } // 同理,設置➡️ let iconChevron = classNames('fa',{'fa-chevron-down' : item.child}) return ( <ul> <li className={item.level} key={key} style={itemStyle}> <i aria-hidden="true" className={iconChevron} onClick={this.handleClick.bind(this)}></i> {this.itemTitle(item)} </li> {/* 如果當前子元素還有子元素,就遞歸使用tree方法,把當前子元素的子元素渲染出來 */} {this.tree(item.child)} </ul> ) }) } return treeItem } render() { return ( <div className="tree"> { this.treeItemCroup(this.props.treeList) } </div> ); } } export default Tree;
效果圖:
DOM結構圖
代碼我加了一些注釋,可能還是比較難理清楚邏輯 😫
當前的邏輯我覺得有點混亂,希望看的朋友們能給出一點建議,感激不盡
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
使用useImperativeHandle時父組件第一次沒拿到子組件的問題
這篇文章主要介紹了使用useImperativeHandle時父組件第一次沒拿到子組件的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08使用React?Redux實現(xiàn)React組件之間的數(shù)據(jù)共享
在復雜的React應用中,組件之間的數(shù)據(jù)共享是必不可少的,為了解決這個問題,可以使用React?Redux來管理應用的狀態(tài),并實現(xiàn)組件之間的數(shù)據(jù)共享,在本文中,我們將介紹如何使用React?Redux實現(xiàn)Count和Person組件之間的數(shù)據(jù)共享,需要的朋友可以參考下2024-03-03Remix后臺開發(fā)之remix-antd-admin配置過程
這篇文章主要為大家介紹了Remix后臺開發(fā)之remix-antd-admin配置過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04react以create-react-app為基礎創(chuàng)建項目
這篇文章主要介紹了react以create-react-app為基礎創(chuàng)建項目,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03