react插件,樹(shù)狀圖(可自由定義子節(jié)點(diǎn)結(jié)構(gòu)蝎抽,大小政钟,樣式)

react插件,樹(shù)狀圖(可自由定義子節(jié)點(diǎn)結(jié)構(gòu)樟结,大小养交,樣式)

如果覺(jué)得看下面的代碼和說(shuō)明還沒(méi)明白,可以直接去github倉(cāng)庫(kù)拉代碼,源碼和說(shuō)明里面都有(https://github.com/jiangji1/react_tree_j)

先上效果圖

效果圖


image

效果圖


image

安裝

安裝 npm install react_tree_j

引入瓢宦,使用

import React from 'react';
import ReactTree from './react_tree_j';
function childLayout (props) {
  return <div onClick={ () => { props.click(props.path, props.data) } }>
    {props.data.agntname} // 或者隨便寫(xiě)什么 {props.data.name} 或者直接寫(xiě)123碎连,都行
  </div>
}
class App extends React.Component {
  click = (obj) => {
    console.log(obj)
  }
  render () {
    return <ReactTree data={json數(shù)據(jù)} showAll={false} click={this.click} childLayout={childLayout} size={1} />
  }
}
/* 說(shuō)明(description)
  必傳   1.data是一個(gè)json數(shù)據(jù)
  必傳   2.childLayout是react的函數(shù)組件,返回的dom元素是每個(gè)子節(jié)點(diǎn),大小決定樹(shù)狀圖的大小, 接受一個(gè)對(duì)象props(Object類(lèi)型)
  props.data 是 每個(gè)子節(jié)點(diǎn)的數(shù)據(jù) Object類(lèi)型
  props.tier 是 第幾層級(jí) Number類(lèi)型
  props.path 是 屬于父節(jié)點(diǎn)子集的下標(biāo)
  props.click 是 function,接受2個(gè)參數(shù),第1個(gè)參數(shù)把props.path傳入,第2個(gè)參數(shù)把props.data傳入
  childLayout具體參考下面的childLayout函數(shù)

  非必傳 3.click一個(gè)函數(shù)驮履,接受一個(gè)參數(shù)鱼辙,參數(shù)是點(diǎn)擊每個(gè)子節(jié)點(diǎn)數(shù)據(jù)(是當(dāng)前點(diǎn)擊的節(jié)點(diǎn)的所有屬性)
  非必傳 4.showAll是一個(gè)Boolean類(lèi)型(不是非要布爾類(lèi)型,js會(huì)隱式轉(zhuǎn)換),如果是true,把數(shù)據(jù)全部顯示,如果是false或者不傳玫镐,就會(huì)默認(rèn)顯示數(shù)據(jù)最左邊一列, 只要點(diǎn)擊就能切換節(jié)點(diǎn)顯示
  非必傳 5.size是一個(gè)Number,如果覺(jué)得每一層dom元素?fù)頂D倒戏,可以傳入數(shù)字進(jìn)行調(diào)節(jié)每一層的間距
*/
childLayout具體參考這里(先看上面的說(shuō)明)
// 每一個(gè)子節(jié)點(diǎn)的結(jié)構(gòu)和樣式(最簡(jiǎn)潔的)
function childLayout (props) {
  // 非常重要!非常重要恐似!非常重要杜跷!這里的onClick給dom綁定點(diǎn)擊事件,復(fù)制黏貼就行了,不能改更,只能寫(xiě)成onClick={() => {props.click(props.path, props.data)
  return <div onClick={ () => { props.click(props.path, props.data) } }>
    {props.data.agntname} // 或者隨便寫(xiě)什么 {props.data.name} 或者直接寫(xiě)123葱椭,都行
  </div>
}

// 每一個(gè)子節(jié)點(diǎn)的結(jié)構(gòu)和樣式(src中demo的說(shuō)明)
function childLayout (props) {
  console.log(props)
  // bgcArr是每一層的圖標(biāo)顏色(就是demo的小圓圈的顏色) props.tier就是為了這里每層使用不同顏色,沒(méi)有其他用處
  let bgcArr = ['#0DC0AF', '#FD71AA', '#41A3FC', '#D086EB', '#F8B551']
  return <div>
    <span>
      // 這里style就是為了設(shè)置背景色口四,不重要
      <div style={{'--background_color': bgcArr[props.tier % bgcArr.length] || '#fff'}}>
        // 非常重要孵运!非常重要!非常重要蔓彩!這里的onClick給dom綁定點(diǎn)擊事件,復(fù)制黏貼就行了治笨,不能改更,只能寫(xiě)成onClick={() => {props.click(props.path, props.data)
        <div className='shu_show_name' onClick={() => {
        props.click(props.path, props.data)
      }} style={{backgroundColor: 'var(--background_color)'}}>
        {props.data.agtype}
      </div>
      <div className="shu_show_all_name">
        <div>{props.data.agntname}</div>
      </div>
      </div>
    </span>
  </div>
}

最后附上一個(gè)json數(shù)據(jù)

{"agntname":"agntname","agtype":"agtype","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"崔某某","agtype":"UM","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS"},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]},{"agntname":"崔某某","agtype":"SS","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]},{"agntname":"杜某某","agtype":"SS","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]}]},{"agntname":"段某某","agtype":"UM","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]},{"agntname":"崔某某","agtype":"SS","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]},{"agntname":"杜某某","agtype":"SS","child":[{"agntname":"陸某某","agtype":"HD","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"侯某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]},{"agntname":"賈某某","agtype":"AS","child":[{"agntname":"陸某某","agtype":"HD"},{"agntname":"鄭鈺","agtype":"SD"},{"agntname":"周珊珊","agtype":"SE"},{"agntname":"周睿","agtype":"TA"}]}]}]}]}]}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末赤嚼,一起剝皮案震驚了整個(gè)濱河市旷赖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌更卒,老刑警劉巖等孵,帶你破解...
    沈念sama閱讀 223,126評(píng)論 6 520
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異蹂空,居然都是意外死亡俯萌,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,421評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門(mén)上枕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)咐熙,“玉大人,你說(shuō)我怎么就攤上這事辨萍∑迥眨” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,941評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵锈玉,是天一觀(guān)的道長(zhǎng)爪飘。 經(jīng)常有香客問(wèn)我,道長(zhǎng)嘲玫,這世上最難降的妖魔是什么悦施? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,294評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮去团,結(jié)果婚禮上抡诞,老公的妹妹穿的比我還像新娘。我一直安慰自己土陪,他們只是感情好昼汗,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,295評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著鬼雀,像睡著了一般顷窒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,874評(píng)論 1 314
  • 那天鞋吉,我揣著相機(jī)與錄音鸦做,去河邊找鬼。 笑死谓着,一個(gè)胖子當(dāng)著我的面吹牛泼诱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赊锚,決...
    沈念sama閱讀 41,285評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼治筒,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了舷蒲?” 一聲冷哼從身側(cè)響起耸袜,我...
    開(kāi)封第一講書(shū)人閱讀 40,249評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎牲平,沒(méi)想到半個(gè)月后堤框,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,760評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡纵柿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,840評(píng)論 3 343
  • 正文 我和宋清朗相戀三年胰锌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藐窄。...
    茶點(diǎn)故事閱讀 40,973評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡资昧,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出荆忍,到底是詐尸還是另有隱情格带,我是刑警寧澤,帶...
    沈念sama閱讀 36,631評(píng)論 5 351
  • 正文 年R本政府宣布刹枉,位于F島的核電站叽唱,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏微宝。R本人自食惡果不足惜棺亭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,315評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蟋软。 院中可真熱鬧镶摘,春花似錦、人聲如沸岳守。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,797評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)湿痢。三九已至涝缝,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拒逮。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,926評(píng)論 1 275
  • 我被黑心中介騙來(lái)泰國(guó)打工罐氨, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人滩援。 一個(gè)月前我還...
    沈念sama閱讀 49,431評(píng)論 3 379
  • 正文 我出身青樓岂昭,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親狠怨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,982評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 01 “夏天,我的那條藏藍(lán)色的褲子在哪里放著呢记盒?” “如果不在衣柜里的話(huà)憎蛤,那就是我沒(méi)有洗〖退保” “沈夏天俩檬,你可不可以...
    Summer昕小張閱讀 742評(píng)論 0 2
  • 今天晚上我和媽媽還有妹妹去玩過(guò)山車(chē),看到了一個(gè)大哥哥做的時(shí)候碾盟,晃來(lái)晃去的棚辽,很緊張,很害怕的樣子冰肴,我猶豫了一下屈藐,還是...
    簡(jiǎn)單的幸福_9ff4閱讀 178評(píng)論 0 0
  • 四個(gè)領(lǐng)袖特質(zhì) 熱切渴望 堅(jiān)定信念 有效行動(dòng) 鋼鐵意志 五 1.理想宣告團(tuán)隊(duì)目標(biāo),行動(dòng)熙尉、結(jié)果驗(yàn)證團(tuán)隊(duì) 2.團(tuán)隊(duì)贏 個(gè)...
    小米_4fc4閱讀 1,514評(píng)論 0 1
  • 【今日測(cè)試】 本題為1999年考研真題联逻,試試吧! (多選題)1.在下列命題中检痰,包含辯證法思想的有 A.“窮則變包归,變...
    阿飛fighting閱讀 662評(píng)論 0 0