免费资源分享网
.
您的当前位置:主页 > 学习资源 > css教程 
如何解决表数据复制后高亮效果交替出现的问题
来源:php中文网 | 编辑:DDD | 时间:2025-04-23

如何解决表数据复制后高亮效果交替出现的问题?

在数据操作过程中,确保用户能够清晰地看到操作结果至关重要。目前的系统中,用户在点击菜单切换表数据并复制数据后,通过执行copycell方法进行数据复制,随后通过getdata方法获取新的表数据。然而,第一次复制数据后,高亮效果并未按预期显示,而是在第二次复制时才出现,之后的高亮效果显示与否呈现出交替的模式。本文将探讨如何解决这一高亮效果交替出现的问题。

根据提供的代码,复制操作和高亮显示的逻辑主要集中在copyCell和scrollToRow方法中。特别是scrollToRow方法负责处理跳转到指定页面并为对应行添加高亮样式。以下是经过调整的scrollToRow方法,通过这些修改,我们希望能够解决高亮效果的交替问题:

const scrollToRow = (rowKey) => {
  const row = dataSource.value.find((row) => row["ID"] === rowKey);
  const targetIndex = dataSource.value.findIndex(
 (item) => JSON.stringify(item.key) == JSON.stringify(row.key)
  );
  if (targetIndex !== -1) {
 const currentPageSize = paginationConfig.value.defaultPageSize;
 const targetPage = Math.floor(targetIndex / currentPageSize) + 1;
 paginationConfig.value.current = targetPage;
  }
  if (row) {
 setTimeout(() => {
const tableBody = tableRef.value?.$el.querySelector(".ant-table-body");
if (tableBody) {
  const rowElement = tableBody.querySelector(
 `table .ant-table-tbody tr[data-row-key="${row.key}"]`
  );
<pre class="brush:php;toolbar:false"> // 移除所有已高亮的行
 const allHighlightedRows = tableBody.querySelectorAll(".highlighted-row");
 allHighlightedRows.forEach(el => {
el.classList.remove("highlighted-row");
 });

 if (rowElement) {
// 使用 requestAnimationFrame 确保样式应用在下一帧
requestAnimationFrame(() => {
  rowElement.classList.add("highlighted-row");

  // 计算并设置滚动位置
  const tableBodyScrollTop = rowElement.offsetTop - tableBody.offsetTop;
  tableBody.scrollTop = tableBodyScrollTop;
});
 }
  }
}, 100); // 增加延迟时间

} else { console.warn("未找到指定 rowKey 的行"); } };

在调整后的scrollToRow方法中,我们采取了以下措施:

  1. 移除所有已高亮的行:通过查询所有带有highlighted-row类的元素,并移除其类名,确保在添加新高亮时不会有冲突。
  2. 使用setTimeout和requestAnimationFrame:增加了一个短暂的延迟时间(100毫秒),确保DOM更新后再进行高亮操作。同时,使用requestAnimationFrame来确保高亮样式的应用发生在下一帧,确保浏览器有时间更新样式。

通过以上调整,我们期望在每次复制数据后,高亮效果都能稳定地显示在对应行上,而不出现交替的情况。这不仅提高了用户体验,也确保了操作反馈的即时性和准确性。

如何解决表数据复制后高亮效果交替出现的问题?

标签:   浏览器      dom      console   
相关推荐

免费资源分享网 (www.free65.com) 联系QQ:66918338 邮箱:66918338@qq.com

Copyright © 2025-2030 免费资源分享网 备案号:鄂 IPC 2025112587 号