From aa8e176fc77bb9c80b6d614e18391c316581970f Mon Sep 17 00:00:00 2001
From: tanjinzhou <415800467@qq.com>
Date: Mon, 10 Aug 2020 18:36:55 +0800
Subject: [PATCH] fix: table loop render
---
antdv-demo | 2 +-
components/button/button.jsx | 3 +--
components/dropdown/dropdown.jsx | 6 +++---
components/table/FilterDropdownMenuWrapper.jsx | 14 --------------
components/table/filterDropdown.jsx | 5 +----
components/table/interface.js | 11 +++++------
components/vc-table/src/ColumnManager.jsx | 5 +++--
components/vc-table/src/ExpandableTable.jsx | 6 ++++--
components/vc-table/src/Table.jsx | 3 ++-
components/vc-table/src/TableCell.jsx | 4 ++--
components/vc-table/src/TableRow.jsx | 5 +----
examples/App.vue | 2 +-
12 files changed, 24 insertions(+), 42 deletions(-)
diff --git a/antdv-demo b/antdv-demo
index 3978ece8f..4a986352a 160000
--- a/antdv-demo
+++ b/antdv-demo
@@ -1 +1 @@
-Subproject commit 3978ece8febab44f9007ea66df2adc20d65982c4
+Subproject commit 4a986352a599904cfe895d0df1a8bb794e684645
diff --git a/components/button/button.jsx b/components/button/button.jsx
index 865fdede1..17294620b 100644
--- a/components/button/button.jsx
+++ b/components/button/button.jsx
@@ -66,7 +66,6 @@ export default {
sLoading,
ghost,
block,
- icon,
$attrs,
} = this;
const getPrefixCls = this.configProvider.getPrefixCls;
@@ -86,7 +85,7 @@ export default {
default:
break;
}
- const iconType = sLoading ? 'loading' : icon;
+ const iconType = sLoading ? 'loading' : this.iconCom;
return {
[$attrs.class]: $attrs.class,
[`${prefixCls}`]: true,
diff --git a/components/dropdown/dropdown.jsx b/components/dropdown/dropdown.jsx
index 5a242e7f5..5a5bf205c 100644
--- a/components/dropdown/dropdown.jsx
+++ b/components/dropdown/dropdown.jsx
@@ -84,9 +84,9 @@ const Dropdown = {
const { getPopupContainer: getContextPopupContainer } = this.configProvider;
const getPrefixCls = this.configProvider.getPrefixCls;
const prefixCls = getPrefixCls('dropdown', customizePrefixCls);
-
- const dropdownTrigger = cloneElement(getSlot(this), {
- class: classNames(this.$attrs?.class, `${prefixCls}-trigger`),
+ const child = getSlot(this)[0];
+ const dropdownTrigger = cloneElement(child, {
+ class: classNames(child?.props?.class, `${prefixCls}-trigger`),
disabled,
});
const triggerActions = disabled ? [] : trigger;
diff --git a/components/table/FilterDropdownMenuWrapper.jsx b/components/table/FilterDropdownMenuWrapper.jsx
index 3ecb672e5..28c4b2901 100644
--- a/components/table/FilterDropdownMenuWrapper.jsx
+++ b/components/table/FilterDropdownMenuWrapper.jsx
@@ -1,17 +1,3 @@
-// export default {
-// name: 'FilterDropdownMenuWrapper',
-// methods: {
-// handelClick(e) {
-// e.stopPropagation();
-// //this.$emit('click', e);
-// },
-// },
-// render() {
-// const { $slots, handelClick } = this;
-// return
{$slots.default}
;
-// },
-// };
-
const FilterDropdownMenuWrapper = (_, { attrs, slots }) => {
return (
e.stopPropagation()}>
diff --git a/components/table/filterDropdown.jsx b/components/table/filterDropdown.jsx
index 322b44b03..327517bb1 100755
--- a/components/table/filterDropdown.jsx
+++ b/components/table/filterDropdown.jsx
@@ -134,13 +134,10 @@ export default {
handleConfirm() {
this.setVisible(false);
- this.confirmFilter2();
// Call `setSelectedKeys` & `confirm` in the same time will make filter data not up to date
// https://github.com/ant-design/ant-design/issues/12284
this.$forceUpdate();
- this.$nextTick(() => {
- this.confirmFilter;
- });
+ this.$nextTick(this.confirmFilter2);
},
onVisibleChange(visible) {
diff --git a/components/table/interface.js b/components/table/interface.js
index eee9338f8..f41294466 100644
--- a/components/table/interface.js
+++ b/components/table/interface.js
@@ -115,13 +115,9 @@ export const TableProps = {
expandIconAsCell: PropTypes.bool,
expandIconColumnIndex: PropTypes.number,
expandRowByClick: PropTypes.bool,
- // onExpandedRowsChange?: (expandedRowKeys: string[] | number[]) => void;
- // onExpand?: (expanded: boolean, record: T) => void;
- // onChange?: (pagination: PaginationProps | boolean, filters: string[], sorter: Object) => any;
loading: PropTypes.oneOfType([PropTypes.shape(SpinProps).loose, PropTypes.bool]),
locale: TableLocale,
indentSize: PropTypes.number,
- // onRowClick?: (record: T, index: number, event: Event) => any;
customRow: PropTypes.func,
customHeaderRow: PropTypes.func,
useFixedHeader: PropTypes.bool,
@@ -137,7 +133,10 @@ export const TableProps = {
getPopupContainer: PropTypes.func,
expandIcon: PropTypes.func,
transformCellText: PropTypes.func,
- // className?: PropTypes.string,
+ onExpandedRowsChange: PropTypes.func,
+ onExpand: PropTypes.func,
+ onChange: PropTypes.func,
+ onRowClick: PropTypes.func,
// style?: React.CSSProperties;
// children?: React.ReactNode;
};
@@ -169,10 +168,10 @@ export const SelectionCheckboxAllProps = {
getRecordKey: PropTypes.func,
data: PropTypes.array,
prefixCls: PropTypes.string,
- // onSelect: (key: string, index: number, selectFunc: any) => void;
hideDefaultSelections: PropTypes.bool,
selections: PropTypes.oneOfType([PropTypes.array, PropTypes.bool]),
getPopupContainer: PropTypes.func,
+ onSelect: PropTypes.func,
};
// export interface SelectionCheckboxAllState {
diff --git a/components/vc-table/src/ColumnManager.jsx b/components/vc-table/src/ColumnManager.jsx
index 8aac14def..3f40ebf7b 100644
--- a/components/vc-table/src/ColumnManager.jsx
+++ b/components/vc-table/src/ColumnManager.jsx
@@ -1,6 +1,7 @@
+import { toRaw } from 'vue';
export default class ColumnManager {
constructor(columns) {
- this.columns = columns;
+ this.columns = toRaw(columns);
this._cached = {};
}
@@ -89,7 +90,7 @@ export default class ColumnManager {
}
reset(columns) {
- this.columns = columns;
+ this.columns = toRaw(columns);
this._cached = {};
}
diff --git a/components/vc-table/src/ExpandableTable.jsx b/components/vc-table/src/ExpandableTable.jsx
index b74f2740b..644a469ed 100644
--- a/components/vc-table/src/ExpandableTable.jsx
+++ b/components/vc-table/src/ExpandableTable.jsx
@@ -233,8 +233,10 @@ const ExpandableTable = {
const needIndentSpaced = data.some(record => record[childrenColumnName]);
return getSlot(this, 'default', {
- props,
- ...this.$attrs,
+ props: {
+ ...props,
+ ...this.$attrs,
+ },
needIndentSpaced,
renderRows: this.renderRows,
handleExpandChange: this.handleExpandChange,
diff --git a/components/vc-table/src/Table.jsx b/components/vc-table/src/Table.jsx
index 57ed5616d..943ab19ad 100644
--- a/components/vc-table/src/Table.jsx
+++ b/components/vc-table/src/Table.jsx
@@ -88,7 +88,7 @@ export default {
data() {
this.preData = [...this.data];
return {
- columnManager: new ColumnManager(this.columns),
+ columnManager: markRaw(new ColumnManager(this.columns)),
sComponents: markRaw(
merge(
{
@@ -178,6 +178,7 @@ export default {
mounted() {
this.$nextTick(() => {
+ console.log(this.ref_headTable);
if (this.columnManager.isAnyColumnsFixed()) {
this.handleWindowResize();
this.resizeEvent = addEventListener(window, 'resize', this.debouncedWindowResize);
diff --git a/components/vc-table/src/TableCell.jsx b/components/vc-table/src/TableCell.jsx
index 6dfa64a3c..b196c6b96 100644
--- a/components/vc-table/src/TableCell.jsx
+++ b/components/vc-table/src/TableCell.jsx
@@ -70,9 +70,9 @@ export default {
let rowSpan;
if (customRender) {
- text = customRender(text, record, index, column);
+ text = customRender({ text, record, index, column });
if (isInvalidRenderCellText(text)) {
- tdProps = text.props || tdProps;
+ tdProps = text.props || text.attrs || tdProps;
({ colSpan, rowSpan } = tdProps);
text = text.children;
}
diff --git a/components/vc-table/src/TableRow.jsx b/components/vc-table/src/TableRow.jsx
index 0855bdccb..0dc7aca48 100644
--- a/components/vc-table/src/TableRow.jsx
+++ b/components/vc-table/src/TableRow.jsx
@@ -56,6 +56,7 @@ const TableRow = {
data() {
// this.shouldRender = this.visible
+ this.rowRef = null;
return {
shouldRender: this.visible,
};
@@ -155,17 +156,13 @@ const TableRow = {
saveRowRef() {
this.rowRef = findDOMNode(this);
-
const { isAnyColumnsFixed, fixed, expandedRow, ancestorKeys } = this;
-
if (!isAnyColumnsFixed) {
return;
}
-
if (!fixed && expandedRow) {
this.setExpandedRowHeight();
}
-
if (!fixed && ancestorKeys.length >= 0) {
this.setRowHeight();
}
diff --git a/examples/App.vue b/examples/App.vue
index 155e1df20..268625d63 100644
--- a/examples/App.vue
+++ b/examples/App.vue
@@ -4,7 +4,7 @@