先放个简单的el-table例子

<el-table
  ref="refTable"
  :data="tableData"
  :load="loadOrgTable"
  :tree-props="{children: 'children', hasChildren: 'hasChildren'}"
  row-key="orgId"
  lazy
  @expand-change="expandChange"
>
</el-table>
1、版本问题

el-table懒加载执行两次,loading未取消的bug,后面升级版本即可。不升级的情况下可以如下面处理。

mounted() {
    // 2.15.3 版本修复了这个bug, 目前版本没有更新 https://github.com/ElemeFE/element/pull/21041
    this.$refs.refTable.store.loadData = function(row, key, treeNode){
      const { load } = this.table;
      const { treeData: rawTreeData } = this.states;
      if (load && !rawTreeData[key].loaded) {
        rawTreeData[key].loading = true;
        load(row, treeNode, data => {
          if (!Array.isArray(data)) {
            throw new Error('[ElTable] data must be an array');
          }
          const { lazyTreeNodeMap, treeData } = this.states;

          // 修复快速切换数据时报错 
          if(!treeData[key]) {
            return
          }
          treeData[key].loading = false;
          treeData[key].loaded = true;
          treeData[key].expanded = true;
          if (data.length) {
            this.$set(lazyTreeNodeMap, key, data);
          }
          this.table.$emit('expand-change', row, true);
        });
      }
    }
  },
2、数据显示

1、tableData是开始时的数据,后面load懒加载的数据都不会在tableData
2、设置tableData=[],并没有清空树里面的数据,如果下次懒加载返回的是空数组,但页面上会显示上一次的数据。(如果你这个时候点击下载数据,就会出现下载的内容跟表格显示的不一致)

resetLazyTree() {   
	// 单独设置这个是无效的,大坑~ 一定要清空孩子,否则loadOrgTable返回数据在没有孩子的情况下会显示上次的孩子节点
	this.tableData = [] 
	this.$set(this.$refs.refTable.store.states, 'lazyTreeNodeMap', {})
},

3、有时表格下方多出一行空白, 或者树形表格加载子节点时,可能出现滚动条,导致行错位。
都可以尝试重新刷新表格布局

// 对 Table 进行重新布局
refreshTableLayout() {
   this.$nextTick(() => {
     this.$refs.refTable.doLayout()
   })
},
3、滚动条

不去改这个默认滚动条的样式,会少很多问题。。。。

element表格树型数据怎么使用赖加载 element树形表格懒加载_数据结构


比如改变了滚动条的宽为现在的一半,那么会出现最后一行的第一列文字被挡住一半。

element表格树型数据怎么使用赖加载 element树形表格懒加载_数据_02


这个先放着,有好的解决办法再来。。。

4、数据结构

element表格树型数据怎么使用赖加载 element树形表格懒加载_树形_03

像这种双表头的表格,数据结构可以如下:

this.tableData = [{
	orgId: 1,
	orgName: '银行境内机构汇总',
	hasChildren: true,
	indData: [
		{
			name:"名字1",
			a: '--',
			b: '--',
		},
		{
			name:"2",
			a: '--',
			b: '--',
		},
	],
	children: [],
}]

如果名字栏的表头先渲染,那么接口indData里面的顺序一定要跟着名字的顺序,否则会出现数据错乱。

5、el-table的fixed导致的问题

场景: 使用excelJs 的DOM类型下载来下载表格中的数据, 在获取el-table下载数据后,发现sheet页中有两份相同的数据。
原因:设置了fixed后,el-table渲染的结构中有两个table
解决办法:通过$refs获取到虚拟dom,删除第二个表的dom即可, 这里不能获取真实的dom, 否则页面受到影响。