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

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

在数据操作过程中,确保用户能够清晰地看到操作结果至关重要。目前的系统中,用户在点击菜单切换表数据并复制数据后,通过执行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来确保高亮样式的应用发生在下一帧,确保浏览器有时间更新样式。

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

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

© 版权声明
THE END
喜欢就支持一下吧
点赞13 分享