在数据操作过程中,确保用户能够清晰地看到操作结果至关重要。目前的系统中,用户在点击菜单切换表数据并复制数据后,通过执行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方法中,我们采取了以下措施:
通过以上调整,我们期望在每次复制数据后,高亮效果都能稳定地显示在对应行上,而不出现交替的情况。这不仅提高了用户体验,也确保了操作反馈的即时性和准确性。
免费资源分享网 (www.free65.com) 联系QQ:66918338 邮箱:66918338@qq.com
Copyright © 2025-2030 免费资源分享网 备案号:鄂 IPC 2025112587 号