提交 6095cb54 编写于 作者: V Vben

fix(table): ensure that the height calculation is normal close #349

上级 2c6aa852
...@@ -23,7 +23,7 @@ export function useTableScroll( ...@@ -23,7 +23,7 @@ export function useTableScroll(
const modalFn = useModalContext(); const modalFn = useModalContext();
// Greater than animation time 280 // Greater than animation time 280
const [debounceRedoHeight] = useDebounce(redoHeight, 200); const [debounceRedoHeight] = useDebounce(redoHeight, 100);
const getCanResize = computed(() => { const getCanResize = computed(() => {
const { canResize, scroll } = unref(propsRef); const { canResize, scroll } = unref(propsRef);
...@@ -41,11 +41,9 @@ export function useTableScroll( ...@@ -41,11 +41,9 @@ export function useTableScroll(
); );
function redoHeight() { function redoHeight() {
if (unref(getCanResize)) { nextTick(() => {
nextTick(() => { calcTableHeight();
calcTableHeight(); });
});
}
} }
function setHeight(heigh: number) { function setHeight(heigh: number) {
...@@ -63,15 +61,23 @@ export function useTableScroll( ...@@ -63,15 +61,23 @@ export function useTableScroll(
const { resizeHeightOffset, pagination, maxHeight } = unref(propsRef); const { resizeHeightOffset, pagination, maxHeight } = unref(propsRef);
const tableData = unref(getDataSourceRef); const tableData = unref(getDataSourceRef);
if (!unref(getCanResize) || tableData.length === 0) return;
await nextTick();
//Add a delay to get the correct bottomIncludeBody paginationHeight footerHeight headerHeight
const table = unref(tableElRef); const table = unref(tableElRef);
if (!table) return; if (!table) return;
const tableEl: Element = table.$el; const tableEl: Element = table.$el;
if (!tableEl) return; if (!tableEl) return;
if (!bodyEl) {
bodyEl = tableEl.querySelector('.ant-table-body');
}
bodyEl!.style.height = 'unset';
if (!unref(getCanResize) || tableData.length === 0) return;
await nextTick();
//Add a delay to get the correct bottomIncludeBody paginationHeight footerHeight headerHeight
const headEl = tableEl.querySelector('.ant-table-thead '); const headEl = tableEl.querySelector('.ant-table-thead ');
if (!headEl) return; if (!headEl) return;
...@@ -124,10 +130,6 @@ export function useTableScroll( ...@@ -124,10 +130,6 @@ export function useTableScroll(
height = (height > maxHeight! ? (maxHeight as number) : height) ?? height; height = (height > maxHeight! ? (maxHeight as number) : height) ?? height;
setHeight(height); setHeight(height);
if (!bodyEl) {
bodyEl = tableEl.querySelector('.ant-table-body');
}
bodyEl!.style.height = `${height}px`; bodyEl!.style.height = `${height}px`;
} }
useWindowSizeFn(calcTableHeight, 280); useWindowSizeFn(calcTableHeight, 280);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册