fix: 行拖拽,表头更新后,拖拽把手丢失

This commit is contained in:
yangchch6 2020-01-07 15:16:46 +08:00
parent 816b84733e
commit b183fde817
7 changed files with 164 additions and 152 deletions

View File

@ -224,7 +224,8 @@ var ColumnManager = function () {
return element && (element.type === _Column2["default"] || element.type === _ColumnGroup2["default"]); return element && (element.type === _Column2["default"] || element.type === _ColumnGroup2["default"]);
}; };
ColumnManager.prototype.reset = function reset(columns, elements, showRowNum) { ColumnManager.prototype.reset = function reset(columns, elements, showRowNum, rowDraggAble) {
columns = this.addDragHandleColumn(columns, rowDraggAble);
columns = this.addOrderColumn(columns, showRowNum); columns = this.addOrderColumn(columns, showRowNum);
columns = this.deleteColumnNotShow(columns); columns = this.deleteColumnNotShow(columns);
this.columns = columns || this.normalize(elements); this.columns = columns || this.normalize(elements);

View File

@ -383,6 +383,10 @@ var Table = function (_Component) {
}; };
Table.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { Table.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
var _props = this.props,
rowDraggAble = _props.rowDraggAble,
showRowNum = _props.showRowNum;
if ('data' in nextProps) { if ('data' in nextProps) {
this.setState({ this.setState({
data: nextProps.data data: nextProps.data
@ -394,12 +398,12 @@ var Table = function (_Component) {
}); });
} }
if (nextProps.columns && nextProps.columns !== this.props.columns) { if (nextProps.columns && nextProps.columns !== this.props.columns) {
this.columnManager.reset(nextProps.columns, null, this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(nextProps.columns, null, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
if (nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable) { if (nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable) {
this.scrollTop = this.bodyTable.scrollTop; this.scrollTop = this.bodyTable.scrollTop;
} }
} else if (nextProps.children !== this.props.children) { } else if (nextProps.children !== this.props.children) {
this.columnManager.reset(null, nextProps.children, this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(null, nextProps.children, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
} }
//适配lazyload //适配lazyload
if (nextProps.scrollTop > -1) { if (nextProps.scrollTop > -1) {
@ -586,33 +590,33 @@ var Table = function (_Component) {
Table.prototype.getHeader = function getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) { Table.prototype.getHeader = function getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) {
var lastShowIndex = this.state.lastShowIndex; var lastShowIndex = this.state.lastShowIndex;
var _props = this.props, var _props2 = this.props,
filterDelay = _props.filterDelay, filterDelay = _props2.filterDelay,
onFilterChange = _props.onFilterChange, onFilterChange = _props2.onFilterChange,
onFilterClear = _props.onFilterClear, onFilterClear = _props2.onFilterClear,
filterable = _props.filterable, filterable = _props2.filterable,
showHeader = _props.showHeader, showHeader = _props2.showHeader,
expandIconAsCell = _props.expandIconAsCell, expandIconAsCell = _props2.expandIconAsCell,
clsPrefix = _props.clsPrefix, clsPrefix = _props2.clsPrefix,
onDragStart = _props.onDragStart, onDragStart = _props2.onDragStart,
onDragEnter = _props.onDragEnter, onDragEnter = _props2.onDragEnter,
onDragOver = _props.onDragOver, onDragOver = _props2.onDragOver,
onDrop = _props.onDrop, onDrop = _props2.onDrop,
onDragEnd = _props.onDragEnd, onDragEnd = _props2.onDragEnd,
draggable = _props.draggable, draggable = _props2.draggable,
onMouseDown = _props.onMouseDown, onMouseDown = _props2.onMouseDown,
onMouseMove = _props.onMouseMove, onMouseMove = _props2.onMouseMove,
onMouseUp = _props.onMouseUp, onMouseUp = _props2.onMouseUp,
dragborder = _props.dragborder, dragborder = _props2.dragborder,
onThMouseMove = _props.onThMouseMove, onThMouseMove = _props2.onThMouseMove,
dragborderKey = _props.dragborderKey, dragborderKey = _props2.dragborderKey,
minColumnWidth = _props.minColumnWidth, minColumnWidth = _props2.minColumnWidth,
headerHeight = _props.headerHeight, headerHeight = _props2.headerHeight,
afterDragColWidth = _props.afterDragColWidth, afterDragColWidth = _props2.afterDragColWidth,
headerScroll = _props.headerScroll, headerScroll = _props2.headerScroll,
bordered = _props.bordered, bordered = _props2.bordered,
onDropBorder = _props.onDropBorder, onDropBorder = _props2.onDropBorder,
onDraggingBorder = _props.onDraggingBorder; onDraggingBorder = _props2.onDraggingBorder;
this.columnsChildrenList = []; //复杂表头拖拽重新render表头前将其置空 this.columnsChildrenList = []; //复杂表头拖拽重新render表头前将其置空
var rows = this.getHeaderRows(columns); var rows = this.getHeaderRows(columns);
@ -752,9 +756,9 @@ var Table = function (_Component) {
}; };
Table.prototype.getExpandedRow = function getExpandedRow(key, content, visible, className, fixed) { Table.prototype.getExpandedRow = function getExpandedRow(key, content, visible, className, fixed) {
var _props2 = this.props, var _props3 = this.props,
clsPrefix = _props2.clsPrefix, clsPrefix = _props3.clsPrefix,
expandIconAsCell = _props2.expandIconAsCell; expandIconAsCell = _props3.expandIconAsCell;
var colCount = void 0; var colCount = void 0;
if (fixed === 'left') { if (fixed === 'left') {
@ -1083,19 +1087,19 @@ var Table = function (_Component) {
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var columns = options.columns, var columns = options.columns,
fixed = options.fixed; fixed = options.fixed;
var _props3 = this.props,
clsPrefix = _props3.clsPrefix,
_props3$scroll = _props3.scroll,
scroll = _props3$scroll === undefined ? {} : _props3$scroll,
getBodyWrapper = _props3.getBodyWrapper,
footerScroll = _props3.footerScroll,
headerScroll = _props3.headerScroll,
_props3$hideHeaderScr = _props3.hideHeaderScroll,
hideHeaderScroll = _props3$hideHeaderScr === undefined ? false : _props3$hideHeaderScr,
expandIconAsCell = _props3.expandIconAsCell;
var _props4 = this.props, var _props4 = this.props,
useFixedHeader = _props4.useFixedHeader, clsPrefix = _props4.clsPrefix,
data = _props4.data; _props4$scroll = _props4.scroll,
scroll = _props4$scroll === undefined ? {} : _props4$scroll,
getBodyWrapper = _props4.getBodyWrapper,
footerScroll = _props4.footerScroll,
headerScroll = _props4.headerScroll,
_props4$hideHeaderScr = _props4.hideHeaderScroll,
hideHeaderScroll = _props4$hideHeaderScr === undefined ? false : _props4$hideHeaderScr,
expandIconAsCell = _props4.expandIconAsCell;
var _props5 = this.props,
useFixedHeader = _props5.useFixedHeader,
data = _props5.data;
var bodyStyle = _extends({}, this.props.bodyStyle); // 这里为什么不写在上面? var bodyStyle = _extends({}, this.props.bodyStyle); // 这里为什么不写在上面?
var headStyle = {}; var headStyle = {};
@ -1287,9 +1291,9 @@ var Table = function (_Component) {
}; };
Table.prototype.getTitle = function getTitle() { Table.prototype.getTitle = function getTitle() {
var _props5 = this.props, var _props6 = this.props,
title = _props5.title, title = _props6.title,
clsPrefix = _props5.clsPrefix; clsPrefix = _props6.clsPrefix;
return title ? _react2["default"].createElement( return title ? _react2["default"].createElement(
'div', 'div',
@ -1299,9 +1303,9 @@ var Table = function (_Component) {
}; };
Table.prototype.getFooter = function getFooter() { Table.prototype.getFooter = function getFooter() {
var _props6 = this.props, var _props7 = this.props,
footer = _props6.footer, footer = _props7.footer,
clsPrefix = _props6.clsPrefix; clsPrefix = _props7.clsPrefix;
return footer ? _react2["default"].createElement( return footer ? _react2["default"].createElement(
'div', 'div',
@ -1311,10 +1315,10 @@ var Table = function (_Component) {
}; };
Table.prototype.getEmptyText = function getEmptyText() { Table.prototype.getEmptyText = function getEmptyText() {
var _props7 = this.props, var _props8 = this.props,
defaultEmptyText = _props7.emptyText, defaultEmptyText = _props8.emptyText,
clsPrefix = _props7.clsPrefix, clsPrefix = _props8.clsPrefix,
data = _props7.data; data = _props8.data;
var locale = (0, _tool.getComponentLocale)(this.props, this.context, 'Table', function () { var locale = (0, _tool.getComponentLocale)(this.props, this.context, 'Table', function () {
return _i18n2["default"]; return _i18n2["default"];
@ -1355,13 +1359,13 @@ var Table = function (_Component) {
Table.prototype.syncFixedTableRowHeight = function syncFixedTableRowHeight() { Table.prototype.syncFixedTableRowHeight = function syncFixedTableRowHeight() {
//this.props.height、headerHeight分别为用户传入的行高和表头高度如果有值所有行的高度都是固定的主要为了避免在千行数据中有固定列时获取行高度有问题 //this.props.height、headerHeight分别为用户传入的行高和表头高度如果有值所有行的高度都是固定的主要为了避免在千行数据中有固定列时获取行高度有问题
var _props8 = this.props, var _props9 = this.props,
clsPrefix = _props8.clsPrefix, clsPrefix = _props9.clsPrefix,
height = _props8.height, height = _props9.height,
headerHeight = _props8.headerHeight, headerHeight = _props9.headerHeight,
columns = _props8.columns, columns = _props9.columns,
heightConsistent = _props8.heightConsistent, heightConsistent = _props9.heightConsistent,
bodyDisplayInRow = _props8.bodyDisplayInRow; bodyDisplayInRow = _props9.bodyDisplayInRow;
var headRows = this.headTable ? this.headTable.querySelectorAll('thead') : this.bodyTable.querySelectorAll('thead'); var headRows = this.headTable ? this.headTable.querySelectorAll('thead') : this.bodyTable.querySelectorAll('thead');
var expandedRows = this.bodyTable.querySelectorAll('.' + clsPrefix + '-expanded-row') || []; var expandedRows = this.bodyTable.querySelectorAll('.' + clsPrefix + '-expanded-row') || [];
@ -1453,13 +1457,13 @@ var Table = function (_Component) {
Table.prototype.handleBodyScroll = function handleBodyScroll(e) { Table.prototype.handleBodyScroll = function handleBodyScroll(e) {
var headTable = this.headTable; var headTable = this.headTable;
var _props9 = this.props, var _props10 = this.props,
_props9$scroll = _props9.scroll, _props10$scroll = _props10.scroll,
scroll = _props9$scroll === undefined ? {} : _props9$scroll, scroll = _props10$scroll === undefined ? {} : _props10$scroll,
clsPrefix = _props9.clsPrefix, clsPrefix = _props10.clsPrefix,
handleScrollY = _props9.handleScrollY, handleScrollY = _props10.handleScrollY,
handleScrollX = _props9.handleScrollX, handleScrollX = _props10.handleScrollX,
onBodyScroll = _props9.onBodyScroll; onBodyScroll = _props10.onBodyScroll;
var _refs = this.refs, var _refs = this.refs,
fixedColumnsBodyLeft = _refs.fixedColumnsBodyLeft, fixedColumnsBodyLeft = _refs.fixedColumnsBodyLeft,
fixedColumnsBodyRight = _refs.fixedColumnsBodyRight; fixedColumnsBodyRight = _refs.fixedColumnsBodyRight;
@ -1516,10 +1520,10 @@ var Table = function (_Component) {
Table.prototype.handleRowHover = function handleRowHover(isHover, key, event, currentIndex, propsRecord) { Table.prototype.handleRowHover = function handleRowHover(isHover, key, event, currentIndex, propsRecord) {
//增加新的API设置是否同步Hover状态提高性能避免无关的渲染 //增加新的API设置是否同步Hover状态提高性能避免无关的渲染
var _props10 = this.props, var _props11 = this.props,
syncHover = _props10.syncHover, syncHover = _props11.syncHover,
onRowHover = _props10.onRowHover, onRowHover = _props11.onRowHover,
data = _props10.data; data = _props11.data;
//fix:树形表onRowHover返回参数异常 //fix:树形表onRowHover返回参数异常
var isTreeType = this.isTreeType; var isTreeType = this.isTreeType;

151
dist/demo.js vendored
View File

@ -37420,6 +37420,10 @@
}; };
Table.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) { Table.prototype.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {
var _props = this.props,
rowDraggAble = _props.rowDraggAble,
showRowNum = _props.showRowNum;
if ('data' in nextProps) { if ('data' in nextProps) {
this.setState({ this.setState({
data: nextProps.data data: nextProps.data
@ -37431,12 +37435,12 @@
}); });
} }
if (nextProps.columns && nextProps.columns !== this.props.columns) { if (nextProps.columns && nextProps.columns !== this.props.columns) {
this.columnManager.reset(nextProps.columns, null, this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(nextProps.columns, null, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
if (nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable) { if (nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable) {
this.scrollTop = this.bodyTable.scrollTop; this.scrollTop = this.bodyTable.scrollTop;
} }
} else if (nextProps.children !== this.props.children) { } else if (nextProps.children !== this.props.children) {
this.columnManager.reset(null, nextProps.children, this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(null, nextProps.children, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
} }
//适配lazyload //适配lazyload
if (nextProps.scrollTop > -1) { if (nextProps.scrollTop > -1) {
@ -37623,33 +37627,33 @@
Table.prototype.getHeader = function getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) { Table.prototype.getHeader = function getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) {
var lastShowIndex = this.state.lastShowIndex; var lastShowIndex = this.state.lastShowIndex;
var _props = this.props, var _props2 = this.props,
filterDelay = _props.filterDelay, filterDelay = _props2.filterDelay,
onFilterChange = _props.onFilterChange, onFilterChange = _props2.onFilterChange,
onFilterClear = _props.onFilterClear, onFilterClear = _props2.onFilterClear,
filterable = _props.filterable, filterable = _props2.filterable,
showHeader = _props.showHeader, showHeader = _props2.showHeader,
expandIconAsCell = _props.expandIconAsCell, expandIconAsCell = _props2.expandIconAsCell,
clsPrefix = _props.clsPrefix, clsPrefix = _props2.clsPrefix,
onDragStart = _props.onDragStart, onDragStart = _props2.onDragStart,
onDragEnter = _props.onDragEnter, onDragEnter = _props2.onDragEnter,
onDragOver = _props.onDragOver, onDragOver = _props2.onDragOver,
onDrop = _props.onDrop, onDrop = _props2.onDrop,
onDragEnd = _props.onDragEnd, onDragEnd = _props2.onDragEnd,
draggable = _props.draggable, draggable = _props2.draggable,
onMouseDown = _props.onMouseDown, onMouseDown = _props2.onMouseDown,
onMouseMove = _props.onMouseMove, onMouseMove = _props2.onMouseMove,
onMouseUp = _props.onMouseUp, onMouseUp = _props2.onMouseUp,
dragborder = _props.dragborder, dragborder = _props2.dragborder,
onThMouseMove = _props.onThMouseMove, onThMouseMove = _props2.onThMouseMove,
dragborderKey = _props.dragborderKey, dragborderKey = _props2.dragborderKey,
minColumnWidth = _props.minColumnWidth, minColumnWidth = _props2.minColumnWidth,
headerHeight = _props.headerHeight, headerHeight = _props2.headerHeight,
afterDragColWidth = _props.afterDragColWidth, afterDragColWidth = _props2.afterDragColWidth,
headerScroll = _props.headerScroll, headerScroll = _props2.headerScroll,
bordered = _props.bordered, bordered = _props2.bordered,
onDropBorder = _props.onDropBorder, onDropBorder = _props2.onDropBorder,
onDraggingBorder = _props.onDraggingBorder; onDraggingBorder = _props2.onDraggingBorder;
this.columnsChildrenList = []; //复杂表头拖拽重新render表头前将其置空 this.columnsChildrenList = []; //复杂表头拖拽重新render表头前将其置空
var rows = this.getHeaderRows(columns); var rows = this.getHeaderRows(columns);
@ -37789,9 +37793,9 @@
}; };
Table.prototype.getExpandedRow = function getExpandedRow(key, content, visible, className, fixed) { Table.prototype.getExpandedRow = function getExpandedRow(key, content, visible, className, fixed) {
var _props2 = this.props, var _props3 = this.props,
clsPrefix = _props2.clsPrefix, clsPrefix = _props3.clsPrefix,
expandIconAsCell = _props2.expandIconAsCell; expandIconAsCell = _props3.expandIconAsCell;
var colCount = void 0; var colCount = void 0;
if (fixed === 'left') { if (fixed === 'left') {
@ -38120,19 +38124,19 @@
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var columns = options.columns, var columns = options.columns,
fixed = options.fixed; fixed = options.fixed;
var _props3 = this.props,
clsPrefix = _props3.clsPrefix,
_props3$scroll = _props3.scroll,
scroll = _props3$scroll === undefined ? {} : _props3$scroll,
getBodyWrapper = _props3.getBodyWrapper,
footerScroll = _props3.footerScroll,
headerScroll = _props3.headerScroll,
_props3$hideHeaderScr = _props3.hideHeaderScroll,
hideHeaderScroll = _props3$hideHeaderScr === undefined ? false : _props3$hideHeaderScr,
expandIconAsCell = _props3.expandIconAsCell;
var _props4 = this.props, var _props4 = this.props,
useFixedHeader = _props4.useFixedHeader, clsPrefix = _props4.clsPrefix,
data = _props4.data; _props4$scroll = _props4.scroll,
scroll = _props4$scroll === undefined ? {} : _props4$scroll,
getBodyWrapper = _props4.getBodyWrapper,
footerScroll = _props4.footerScroll,
headerScroll = _props4.headerScroll,
_props4$hideHeaderScr = _props4.hideHeaderScroll,
hideHeaderScroll = _props4$hideHeaderScr === undefined ? false : _props4$hideHeaderScr,
expandIconAsCell = _props4.expandIconAsCell;
var _props5 = this.props,
useFixedHeader = _props5.useFixedHeader,
data = _props5.data;
var bodyStyle = _extends({}, this.props.bodyStyle); // 这里为什么不写在上面? var bodyStyle = _extends({}, this.props.bodyStyle); // 这里为什么不写在上面?
var headStyle = {}; var headStyle = {};
@ -38324,9 +38328,9 @@
}; };
Table.prototype.getTitle = function getTitle() { Table.prototype.getTitle = function getTitle() {
var _props5 = this.props, var _props6 = this.props,
title = _props5.title, title = _props6.title,
clsPrefix = _props5.clsPrefix; clsPrefix = _props6.clsPrefix;
return title ? _react2['default'].createElement( return title ? _react2['default'].createElement(
'div', 'div',
@ -38336,9 +38340,9 @@
}; };
Table.prototype.getFooter = function getFooter() { Table.prototype.getFooter = function getFooter() {
var _props6 = this.props, var _props7 = this.props,
footer = _props6.footer, footer = _props7.footer,
clsPrefix = _props6.clsPrefix; clsPrefix = _props7.clsPrefix;
return footer ? _react2['default'].createElement( return footer ? _react2['default'].createElement(
'div', 'div',
@ -38348,10 +38352,10 @@
}; };
Table.prototype.getEmptyText = function getEmptyText() { Table.prototype.getEmptyText = function getEmptyText() {
var _props7 = this.props, var _props8 = this.props,
defaultEmptyText = _props7.emptyText, defaultEmptyText = _props8.emptyText,
clsPrefix = _props7.clsPrefix, clsPrefix = _props8.clsPrefix,
data = _props7.data; data = _props8.data;
var locale = (0, _tool.getComponentLocale)(this.props, this.context, 'Table', function () { var locale = (0, _tool.getComponentLocale)(this.props, this.context, 'Table', function () {
return _i18n2['default']; return _i18n2['default'];
@ -38392,13 +38396,13 @@
Table.prototype.syncFixedTableRowHeight = function syncFixedTableRowHeight() { Table.prototype.syncFixedTableRowHeight = function syncFixedTableRowHeight() {
//this.props.height、headerHeight分别为用户传入的行高和表头高度如果有值所有行的高度都是固定的主要为了避免在千行数据中有固定列时获取行高度有问题 //this.props.height、headerHeight分别为用户传入的行高和表头高度如果有值所有行的高度都是固定的主要为了避免在千行数据中有固定列时获取行高度有问题
var _props8 = this.props, var _props9 = this.props,
clsPrefix = _props8.clsPrefix, clsPrefix = _props9.clsPrefix,
height = _props8.height, height = _props9.height,
headerHeight = _props8.headerHeight, headerHeight = _props9.headerHeight,
columns = _props8.columns, columns = _props9.columns,
heightConsistent = _props8.heightConsistent, heightConsistent = _props9.heightConsistent,
bodyDisplayInRow = _props8.bodyDisplayInRow; bodyDisplayInRow = _props9.bodyDisplayInRow;
var headRows = this.headTable ? this.headTable.querySelectorAll('thead') : this.bodyTable.querySelectorAll('thead'); var headRows = this.headTable ? this.headTable.querySelectorAll('thead') : this.bodyTable.querySelectorAll('thead');
var expandedRows = this.bodyTable.querySelectorAll('.' + clsPrefix + '-expanded-row') || []; var expandedRows = this.bodyTable.querySelectorAll('.' + clsPrefix + '-expanded-row') || [];
@ -38490,13 +38494,13 @@
Table.prototype.handleBodyScroll = function handleBodyScroll(e) { Table.prototype.handleBodyScroll = function handleBodyScroll(e) {
var headTable = this.headTable; var headTable = this.headTable;
var _props9 = this.props, var _props10 = this.props,
_props9$scroll = _props9.scroll, _props10$scroll = _props10.scroll,
scroll = _props9$scroll === undefined ? {} : _props9$scroll, scroll = _props10$scroll === undefined ? {} : _props10$scroll,
clsPrefix = _props9.clsPrefix, clsPrefix = _props10.clsPrefix,
handleScrollY = _props9.handleScrollY, handleScrollY = _props10.handleScrollY,
handleScrollX = _props9.handleScrollX, handleScrollX = _props10.handleScrollX,
onBodyScroll = _props9.onBodyScroll; onBodyScroll = _props10.onBodyScroll;
var _refs = this.refs, var _refs = this.refs,
fixedColumnsBodyLeft = _refs.fixedColumnsBodyLeft, fixedColumnsBodyLeft = _refs.fixedColumnsBodyLeft,
fixedColumnsBodyRight = _refs.fixedColumnsBodyRight; fixedColumnsBodyRight = _refs.fixedColumnsBodyRight;
@ -38553,10 +38557,10 @@
Table.prototype.handleRowHover = function handleRowHover(isHover, key, event, currentIndex, propsRecord) { Table.prototype.handleRowHover = function handleRowHover(isHover, key, event, currentIndex, propsRecord) {
//增加新的API设置是否同步Hover状态提高性能避免无关的渲染 //增加新的API设置是否同步Hover状态提高性能避免无关的渲染
var _props10 = this.props, var _props11 = this.props,
syncHover = _props10.syncHover, syncHover = _props11.syncHover,
onRowHover = _props10.onRowHover, onRowHover = _props11.onRowHover,
data = _props10.data; data = _props11.data;
//fix:树形表onRowHover返回参数异常 //fix:树形表onRowHover返回参数异常
var isTreeType = this.isTreeType; var isTreeType = this.isTreeType;
@ -86433,7 +86437,8 @@
return element && (element.type === _Column2['default'] || element.type === _ColumnGroup2['default']); return element && (element.type === _Column2['default'] || element.type === _ColumnGroup2['default']);
}; };
ColumnManager.prototype.reset = function reset(columns, elements, showRowNum) { ColumnManager.prototype.reset = function reset(columns, elements, showRowNum, rowDraggAble) {
columns = this.addDragHandleColumn(columns, rowDraggAble);
columns = this.addOrderColumn(columns, showRowNum); columns = this.addOrderColumn(columns, showRowNum);
columns = this.deleteColumnNotShow(columns); columns = this.deleteColumnNotShow(columns);
this.columns = columns || this.normalize(elements); this.columns = columns || this.normalize(elements);

2
dist/demo.js.map vendored

File diff suppressed because one or more lines are too long

View File

@ -81,8 +81,8 @@ import 'bee-table/build/Table.css';
| size | 表格大小 | `sm / md / lg` | 'md' | | size | 表格大小 | `sm / md / lg` | 'md' |
| hideHeaderScroll | 表体无数据时,表头下是否显示滚动条,默认显示 | bool | false | | hideHeaderScroll | 表体无数据时,表头下是否显示滚动条,默认显示 | bool | false |
| [v2.2.2新增]showRowNum | 展示序号功能false时不展示true时展示默认情况可传入自定义配置信息 | bool / obj:{name: '序号', key: '_index', // 在数据中存储的key值width: 50,base: 0,// 排序的基准值,为数字或者字母type:'number', // 排序类型,默认为number类型,支持单字母排序(type='ascii')} | false | | [v2.2.2新增]showRowNum | 展示序号功能false时不展示true时展示默认情况可传入自定义配置信息 | bool / obj:{name: '序号', key: '_index', // 在数据中存储的key值width: 50,base: 0,// 排序的基准值,为数字或者字母type:'number', // 排序类型,默认为number类型,支持单字母排序(type='ascii')} | false |
| autoCheckedByClickRows | 设置为 false 时,表格行点击事件,不会自动勾选复选框 | bool | true | | [v2.2.8新增]autoCheckedByClickRows | 设置为 false 时,表格行点击事件,不会自动勾选复选框 | bool | true |
| autoSelect | 树型表格勾选时,是否开启子节点的联动 | bool | false | | [v2.2.8新增]autoSelect | 树型表格勾选时,是否开启子节点的联动 | bool | false |
> 快捷键部分参考示例 (快捷键在table中的简单使用应用) > 快捷键部分参考示例 (快捷键在table中的简单使用应用)

View File

@ -222,7 +222,8 @@ export default class ColumnManager {
return element && (element.type === Column || element.type === ColumnGroup); return element && (element.type === Column || element.type === ColumnGroup);
} }
reset(columns, elements, showRowNum) { reset(columns, elements, showRowNum, rowDraggAble) {
columns = this.addDragHandleColumn(columns,rowDraggAble);
columns = this.addOrderColumn(columns,showRowNum); columns = this.addOrderColumn(columns,showRowNum);
columns = this.deleteColumnNotShow(columns); columns = this.deleteColumnNotShow(columns);
this.columns = columns || this.normalize(elements); this.columns = columns || this.normalize(elements);

View File

@ -198,6 +198,7 @@ class Table extends Component {
} }
componentWillReceiveProps(nextProps) { componentWillReceiveProps(nextProps) {
let { rowDraggAble, showRowNum } = this.props;
if ('data' in nextProps) { if ('data' in nextProps) {
this.setState({ this.setState({
data: nextProps.data, data: nextProps.data,
@ -209,12 +210,12 @@ class Table extends Component {
}); });
} }
if (nextProps.columns && nextProps.columns !== this.props.columns) { if (nextProps.columns && nextProps.columns !== this.props.columns) {
this.columnManager.reset(nextProps.columns, null, this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(nextProps.columns, null, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
if(nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable){ if(nextProps.columns.length !== this.props.columns.length && this.refs && this.bodyTable){
this.scrollTop = this.bodyTable.scrollTop; this.scrollTop = this.bodyTable.scrollTop;
} }
} else if (nextProps.children !== this.props.children) { } else if (nextProps.children !== this.props.children) {
this.columnManager.reset(null, nextProps.children,this.props.showRowNum); // 加入this.props.showRowNum参数 this.columnManager.reset(null, nextProps.children, showRowNum, rowDraggAble); // 加入this.props.showRowNum参数
} }
//适配lazyload //适配lazyload
if(nextProps.scrollTop > -1){ if(nextProps.scrollTop > -1){