关于elementui plus table的一些操作

表格选择回显

javascript 复制代码
//单条回显
pickTable.value.toggleRowSelection(row, true)
//回显后 全选
const handleSelectionChange = (val: any) => {
  val.map((row: any, index: any) => {
    if (val.length <= 1) {
      return
    }
    pickTable.value.toggleRowSelection(row, false)
    if (index === val.length - 1) {
      pickTable.value.toggleRowSelection(row, true)
    }
  })
}

获取表格所有选项

javascript 复制代码
const arr = pickTable.value.getSelectionRows()

清空选项

javascript 复制代码
 tableRef.value.clearSelection()

树表格懒加载

javascript 复制代码
<el-table v-loading="loading" ref="tableRef" lazy class="custom-table" :data="tableData" row-key="uuid"
          :load="load" :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
          :header-row-style="config.table.header.row" :header-cell-style="config.table.header.cell" :border="true"
          @select="handleSelect" @select-all="handleSelectAll">
          <el-table-column type="selection" reserve-selection width="55" :selectable="selectable" />
          <el-table-column label="工作事项" prop="name" />
        </el-table

//获取列表时需要
 tableData.value.forEach((e) => {
          e["hasChildren"] = true;
          e["leave"] = 1;
          rowMaps.set(e.uuid, e);
        });

//懒加载展开
const load = (row: AssessWorkMatter, treeNode: unknown, resolve: (data: AssessWorkMatter[]) => void) => {
  getSubBaseAuditMatterList(row.uuid).then((data: any) => {
    resolve(data);
  })
};
 
//刷新 stageUuid是父节点的id
const materialRefench = () => {
  if (!stageUuid.value) return
  const data = rowMaps.get(stageUuid.value)
  // 重置节点
  tableRef.value.store.states.treeData.value[data.uuid].loaded = false;
  // 数据处理完成后 加载数据并展开父节点
  tableRef.value.store.loadOrToggle(data);
};
相关推荐
前端摸鱼匠5 分钟前
Vue 3 的defineEmits编译器宏:详解<script setup>中defineEmits的使用
前端·javascript·vue.js·前端框架·ecmascript
里欧跑得慢26 分钟前
Flutter 测试全攻略:从单元测试到集成测试的完整实践
前端·css·flutter·web
Jagger_26 分钟前
前端整洁架构详解
前端
徐小夕36 分钟前
我花一天时间Vibe Coding的开源AI工具,一键检测你的电脑能跑哪些AI大模型
前端·javascript·github
英俊潇洒美少年38 分钟前
Vue3 企业级封装:useEventListener + 终极版 BaseEcharts 组件
前端·javascript·vue.js
嵌入式×边缘AI:打怪升级日志1 小时前
使用JsonRPC实现前后台
前端·后端
小码哥_常2 小时前
深度剖析:为什么Android选择了Binder
前端
方安乐3 小时前
单元测试之helper函数
前端·javascript·单元测试
音仔小瓜皮3 小时前
【Web八股】深入理解浏览器DOM事件流,灵活控制它!
前端·web
灼灼桃花夭3 小时前
js之阳历 → 农历(含时辰)转换函数
开发语言·前端·javascript