使用vue和react创建一个可伸缩的树

对前面树添加一个简单操作,点击可伸缩,对前面的代码改动了下

测试效果分别为(点击前面的+,即可伸展)

 

vue核心组件代码:

<template>
    <div >
        <div v-for="node in treeData">
        <span v-if="node.children" @click="handleClick(node)">+</span>
        <strong >{{node.label}}</strong>
         <vue-tree  :treeData="node.children" v-if="isKey===node.key && isshow"></vue-tree>
        </div>
    </div>
</template>

<script>
export default {
    name:'vue-tree',
    props:['treeData'],
    data(){
        return {
            isshow:false,
            isKey:''
        }
    },
    methods:{
        handleClick(node){
            this.isKey=node.key;
            console.log(this.isshow)
            this.isshow=!this.isshow;
        }
    }
}
</script>

  测试效果代码为:

<template>
  <div>
     <vue-tree :treeData="treeData" ></vue-tree>
  </div>
</template>

<script>
import VueTree from './VueTree';
export default {
  name: 'Home',
  data () {
    return {
      isshow:false,
     treeData:[
      {label:'1',key:'1',children:[{label:'1-1',key:'11'},{label:'1-2',key:'12',children:[{label:'1-2-1',value:'121'}]}]},
      {label:'2',key:'2',children:[{label:'2-1',key:'21'}]}]
    }
  },
  components:{VueTree}
}
</script>

  React核心组件:

import React, { Component } from 'react';
import logo from './logo.svg';
import './App.css';
const treeData=[
      {label:'1',key:'1',children:[{label:'1-1',key:'11'},{label:'1-2',key:'12'}]},
      {label:'2',key:'2',children:[{label:'2-1',key:'21'}]}]

// var isShow=true;
class App extends Component {
  constructor(props) {
    super(props);
    this.state={
      isShow:false,
      current:null
    }
    this.buildTree=this.buildTree.bind(this);
    this.collapse=this.collapse.bind(this);
  }
  buildTree(data){
    return data.map(item=>{
      if(item.children){
         return <div>
          <span onClick={this.collapse}>+<span>{item.label}</span></span> 
          <div style={{display:this.state.isShow &&this.state.current==item.label ?'block':'none'}}>{this.buildTree(item.children)}</div>
         </div> 
      }
      return (<div key={item.key} >{item.label}</div>)
      
    })
  
  }

  collapse(e){
   
    this.setState({isShow:!this.state.isShow});
    this.setState({current:e.target.children[0].innerHTML})
  }
  render() {
    return (
      <div className="App">
        <header className="App-header">
          <img src={logo} className="App-logo" alt="logo" />
          <h1 className="App-title">Welcome to React</h1>
        </header>
       {this.buildTree(treeData)}
      </div>
    );
  }
}

export default App;

  

 

转载于:https://www.cnblogs.com/xingguozhiming/p/9653290.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值