el-table setCurrentRow会触发current-change函数 解决方案

解决el-table setCurrentRow会触发current-change函数问题

javascript 复制代码
<template>
// 直接运行即可
  <template>
  <el-table
      ref="singleTableRef"
      :data="tableData"
      highlight-current-row
      style="width: 100%"
      @current-change="handleCurrentChange"
  >
    <el-table-column type="index" width="50"/>
    <el-table-column property="date" label="Date" width="120"/>
    <el-table-column property="name" label="Name" width="120"/>
    <el-table-column property="address" label="Address"/>
  </el-table>
</template>

<script setup>
import { ref, onMounted, nextTick } from 'vue';

const data = [
  { id: 1, date: '2016-05-03', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
  { id: 2, date: '2016-05-02', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
  { id: 3, date: '2016-05-04', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
  { id: 4, date: '2016-05-01', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
];

const singleTableRef = ref(null); // ref
const tableData = ref([]); // 表格数据
const isUpdating = ref(false); // 用于防止死循环的标识(重点)

// 高亮函数
const setCurrent = (row) => {
  if (singleTableRef.value && !isUpdating.value) {
    nextTick(() => {
      isUpdating.value = true; // 页面渲染完设置为true
      singleTableRef.value.setCurrentRow(row); // 执行高亮
      isUpdating.value = false; // 高亮之后设置为false(防止自执行current-change函数,如果不设置为false,那么就会去触发current-change函数)
    });
  }
};

const handleCurrentChange = (val) => {
  if (isUpdating.value || !val) return; // Prevent loop and handle null/undefined(防止循环和处理null/undefined)

  // Simulate async data update(模拟异步信息-)
  // setTimeout可以换做接口返回数据
  setTimeout(() => {
    const updatedData = [
      { id: 1, date: '2016-05-03', name: '小王', address: 'No. 189, Grove St, Los Angeles' },
      { id: 2, date: '2016-05-02', name: '小王', address: 'No. 189, Grove St, Los Angeles' },
      { id: 3, date: '2016-05-04', name: '小王', address: 'No. 189, Grove St, Los Angeles' },
      { id: 4, date: '2016-05-01', name: '小王', address: 'No. 189, Grove St, Los Angeles' }
    ];

    tableData.value = updatedData; // 用最新的数据或者深拷贝

    nextTick(() => {
      // find查找符合条件的
      const currentRow = updatedData.find(item => item.id === val.id);
      if (currentRow) {
        // 设置高亮
        setCurrent(currentRow);
      }
    });
  }, 1000);
};

onMounted(() => {
  // 这块设置默认选中一项
  setTimeout(() => {
    tableData.value = data;
    nextTick(() => {
      setCurrent(data[1]);
    });
  }, 800);
});
</script>
相关推荐
Cachel wood5 分钟前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
学代码的小前端6 分钟前
0基础学前端-----CSS DAY9
前端·css
joan_8510 分钟前
layui表格templet图片渲染--模板字符串和字符串拼接
前端·javascript·layui
还是大剑师兰特33 分钟前
什么是尾调用,使用尾调用有什么好处?
javascript·大剑师·尾调用
m0_7482361141 分钟前
Calcite Web 项目常见问题解决方案
开发语言·前端·rust
Watermelo6171 小时前
详解js柯里化原理及用法,探究柯里化在Redux Selector 的场景模拟、构建复杂的数据流管道、优化深度嵌套函数中的精妙应用
开发语言·前端·javascript·算法·数据挖掘·数据分析·ecmascript
m0_748248941 小时前
HTML5系列(11)-- Web 无障碍开发指南
前端·html·html5
m0_748235611 小时前
从零开始学前端之HTML(三)
前端·html
一个处女座的程序猿O(∩_∩)O3 小时前
小型 Vue 项目,该不该用 Pinia 、Vuex呢?
前端·javascript·vue.js
hackeroink6 小时前
【2024版】最新推荐好用的XSS漏洞扫描利用工具_xss扫描工具
前端·xss