React TreeSelect设置默认展开项的方法

需要实现TreeSelect组件的onTreeExpand、treeExpandedKeys方法。

代码样例如下:

1.TreeSelect标签部分

a 复制代码
  render() {
      const {
      codeselect
    } = this.props;
    const {treeExpandedKeys} = this.state
................

  <TreeSelect
  showSearch={false}
  dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}
  treeExpandedKeys={treeExpandedKeys}
  onTreeExpand={(data) => {
    this.setState({treeExpandedKeys:[...(data || [])]})
  }}
  treeData={codeselect.managecomTreeData}
  allowClear
  placeholder={
    formatMessage({ id: 'global.input.placeholder' }) +
    formatMessage({ id: 'TrainPlanManage.company' })
  }
  />

其中,实现了treeExpandedKeysonTreeExpand方法。

(1) treeExpandedKeys方法,是要展开的key数组;

(2) onTreeExpand,是点击展开按钮时的操作,需要把点击元素的key放入数组中,就会展开了。

2.js代码部分

a 复制代码
class MyPage extends PureComponent {

  state = {
    treeExpandedKeys:[]
  }
a 复制代码
  componentDidMount(){
    const {codeselect} = this.props;
    // 只展开第一层
    this.setState({treeExpandedKeys:[codeselect.managecomTreeData[0].key]})
  }

(1) 先在state里声明了一个数组,就是用来保存要展开的元素的key的数组

(2) 当页面初始化后,会选取数据中的第0个元素的key,放入要展开的数组中,这样页面就会默认展开数据中的第0个元素。

(注意,后端返回的数据list中,需要有key字段,否则不好实现)

样例图如下,默认展开【1】:

3.备注

Tree标签设置默认展开数据,用的是expandedKeysonExpand

相关推荐
摘星编程11 分钟前
React Native for OpenHarmony 实战:Navigation 导航详解
javascript·react native·react.js
光影少年11 分钟前
next.js与纯react区别
前端·javascript·react.js
2501_9447114316 分钟前
理解 React 自定义 Hook:不只是“封装”,更是思维方式的转变
前端·javascript·react.js
摘星编程27 分钟前
React Native for OpenHarmony 实战:ReactNavigation 导航库详解
javascript·react native·react.js
xiaoxue..31 分钟前
Zustand 状态管理:轻量高效的 React 状态解决方案✨
前端·react.js·面试·状态模式·zustand
PieroPc34 分钟前
Html+css+js 写一个销售单据数据收集工具,会用到小米相机文档功能、NasCab、豆包Ai作为辅助
javascript·css·html
摘星编程36 分钟前
React Native for OpenHarmony 实战:Battery 电池状态详解
javascript·react native·react.js
全栈前端老曹40 分钟前
【前端】Hammer.js 快速上手入门教程
开发语言·前端·javascript·vue·react·移动端开发·hammer.js
亮子AI44 分钟前
【NestJS】为什么return不返回客户端?
前端·javascript·git·nestjs
Filotimo_1 小时前
Vue3 + Element Plus 表格复选框踩坑记录
javascript·vue.js·elementui