tree组件查询后结果渲染问题

img


根据名字查询后,后台直接返回的是三级数据,这种到了页面上不能直接渲染出来,需要怎么处理一下,参数bbiDivision和tree的children一样。

小魔女参考了bing和GPT部分内容调写:
在这种情况下,我们可以使用递归的方式来处理,将后台返回的三级数据转换成tree组件可以识别的格式,以便进行渲染。

具体处理方式如下:

  1. 定义一个函数,传入后台返回的三级数据,返回tree组件可以识别的格式;
  2. 在函数中,遍历后台返回的三级数据,将其转换成tree组件可以识别的格式,并且将children属性设置为一个空数组;
  3. 如果当前节点有子节点,则将当前节点的children属性设置为一个新的数组,并将子节点的数据放入该数组中;
  4. 递归调用函数,直到遍历完所有的节点;
  5. 将处理完的数据传入tree组件,完成渲染。
// 定义函数,传入后台返回的三级数据
function handleData(data) {
  // 定义一个新数组,用于存放处理完的数据
  let newData = [];
  // 遍历后台返回的三级数据
  data.forEach(item => {
    // 将数据转换成tree组件可以识别的格式
    let obj = {
      label: item.name,
      bbiDivision: item.bbiDivision,
      children: []
    };
    // 如果当前节点有子节点,则递归调用函数,处理子节点的数据
    if (item.children && item.children.length > 0) {
      obj.children = handleData(item.children);
    }
    // 将处理完的数据放入新数组中
    newData.push(obj);
  });
  // 返回处理完的数据
  return newData;
}

// 将处理完的数据传入tree组件,完成渲染
<Tree data={handleData(data)} />

回答不易,记得采纳呀。

tree组件有一个prop配置项,可以配置子节点数组的名称,直接将children改成bbiDivision就可以了

<el-tree
  :data="data"
  :props="defaultProps"
  accordion
  @node-click="handleNodeClick">
</el-tree>

<script>
  export default {
    data() {
      return {
        data: [{
          label: '一级 1',
          children: [{
            label: '二级 1-1',
            children: [{
              label: '三级 1-1-1'
            }]
          }]
        }, {
          label: '一级 2',
          children: [{
            label: '二级 2-1',
            children: [{
              label: '三级 2-1-1'
            }]
          }, {
            label: '二级 2-2',
            children: [{
              label: '三级 2-2-1'
            }]
          }]
        }, {
          label: '一级 3',
          children: [{
            label: '二级 3-1',
            children: [{
              label: '三级 3-1-1'
            }]
          }, {
            label: '二级 3-2',
            children: [{
              label: '三级 3-2-1'
            }]
          }]
        }],
        defaultProps: {
          children: 'bbiDivision',
          label: 'label'
        }
      };
    },
    methods: {
      handleNodeClick(data) {
        console.log(data);
      }
    }
  };
</script>