|
1 | | -import { Ref, ref, SetupContext, toRefs, watch } from 'vue'; |
| 1 | +import { Ref, ref, SetupContext, toRefs, watch, nextTick } from 'vue'; |
2 | 2 | import { useConfig } from '@tdesign/shared-hooks'; |
3 | 3 | import Pagination, { PageInfo, PaginationProps } from '../../pagination'; |
4 | 4 | import { TdBaseTableProps, TableRowData } from '../type'; |
@@ -72,20 +72,32 @@ export default function usePagination( |
72 | 72 | size={props.size === 'large' ? null : props.size} |
73 | 73 | {...paginationProps} |
74 | 74 | onChange={(pageInfo: PageInfo) => { |
| 75 | + // 先触发外部 pagination.onChange/onPageSizeChange 回调 |
75 | 76 | props.pagination?.onChange?.(pageInfo); |
76 | | - innerPagination.value = pageInfo; |
77 | | - updateDataSourceAndPaginate(pageInfo.current, pageInfo.pageSize); |
78 | | - props.onPageChange?.(pageInfo, dataSource.value); |
79 | 77 |
|
80 | | - // 当切换分页时,内容区域滚动到顶部 |
81 | | - const ref = tableContentRef.value; |
82 | | - if (ref.scrollTo) { |
83 | | - ref.scrollTo({ top: 0, left: 0 }); |
84 | | - } else { |
85 | | - // 兼容测试环境或旧浏览器 |
86 | | - ref.scrollTop = 0; |
87 | | - ref.scrollLeft = 0; |
88 | | - } |
| 78 | + // 延迟到下一个 tick 再读取受控的 pagination.value,这样如果外部在 |
| 79 | + // onPageSizeChange 中同步设置了 pagination.current(例如重置为 1), |
| 80 | + // 我们可以优先使用外部受控值,避免竞态覆盖。 |
| 81 | + nextTick(() => { |
| 82 | + const finalPageInfo = { |
| 83 | + ...pageInfo, |
| 84 | + current: pagination.value?.current ?? pageInfo.current, |
| 85 | + pageSize: pagination.value?.pageSize ?? pageInfo.pageSize, |
| 86 | + }; |
| 87 | + innerPagination.value = finalPageInfo; |
| 88 | + updateDataSourceAndPaginate(finalPageInfo.current, finalPageInfo.pageSize); |
| 89 | + props.onPageChange?.(finalPageInfo, dataSource.value); |
| 90 | + |
| 91 | + // 当切换分页时,内容区域滚动到顶部 |
| 92 | + const ref = tableContentRef.value; |
| 93 | + if (ref.scrollTo) { |
| 94 | + ref.scrollTo({ top: 0, left: 0 }); |
| 95 | + } else { |
| 96 | + // 兼容测试环境或旧浏览器 |
| 97 | + ref.scrollTop = 0; |
| 98 | + ref.scrollLeft = 0; |
| 99 | + } |
| 100 | + }); |
89 | 101 | }} |
90 | 102 | v-slots={{ totalContent: context.slots.totalContent }} |
91 | 103 | /> |
|
0 commit comments