解决table 交换列中onDragEnd,onDrop 事件回调问题

This commit is contained in:
jonyshi 2019-08-21 16:29:11 +08:00
parent b1ba5b5001
commit 4d88f655d6
14 changed files with 43213 additions and 42094 deletions

View File

@ -241,6 +241,9 @@ import multiSelect from "bee-table/lib/multiSelect.js";
| draggable | 可拖拽交换列 | boolean | false | | draggable | 可拖拽交换列 | boolean | false |
| dragborder | 可拖拽改变列宽 | boolean | false | | dragborder | 可拖拽改变列宽 | boolean | false |
| checkMinSize | 当前表格显示最少列数 | boolean | false | | checkMinSize | 当前表格显示最少列数 | boolean | false |
| onDragEnd | 交换列后的回调函数 | function | (event,data,columns) |
| onDrop | 交换列的回调函数 | function | (event,data,columns) |

View File

@ -566,6 +566,7 @@ var Table = function (_Component) {
onDragEnter = _props.onDragEnter, onDragEnter = _props.onDragEnter,
onDragOver = _props.onDragOver, onDragOver = _props.onDragOver,
onDrop = _props.onDrop, onDrop = _props.onDrop,
onDragEnd = _props.onDragEnd,
draggable = _props.draggable, draggable = _props.draggable,
onMouseDown = _props.onMouseDown, onMouseDown = _props.onMouseDown,
onMouseMove = _props.onMouseMove, onMouseMove = _props.onMouseMove,
@ -592,7 +593,7 @@ var Table = function (_Component) {
} }
var trStyle = headerHeight && !fixed ? { height: headerHeight } : fixed ? this.getHeaderRowStyle(columns, rows) : null; var trStyle = headerHeight && !fixed ? { height: headerHeight } : fixed ? this.getHeaderRowStyle(columns, rows) : null;
var drop = draggable ? { onDragStart: onDragStart, onDragOver: onDragOver, onDrop: onDrop, onDragEnter: onDragEnter, draggable: draggable } : {}; var drop = draggable ? { onDragStart: onDragStart, onDragOver: onDragOver, onDrop: onDrop, onDragEnd: onDragEnd, onDragEnter: onDragEnter, draggable: draggable } : {};
var dragBorder = dragborder ? { onMouseDown: onMouseDown, onMouseMove: onMouseMove, onMouseUp: onMouseUp, dragborder: dragborder, onThMouseMove: onThMouseMove, dragborderKey: dragborderKey, onDropBorder: onDropBorder, onDraggingBorder: onDraggingBorder } : {}; var dragBorder = dragborder ? { onMouseDown: onMouseDown, onMouseMove: onMouseMove, onMouseUp: onMouseUp, dragborder: dragborder, onThMouseMove: onThMouseMove, dragborderKey: dragborderKey, onDropBorder: onDropBorder, onDraggingBorder: onDraggingBorder } : {};
var contentWidthDiff = 0; var contentWidthDiff = 0;
//非固定表格,宽度不够时自动扩充 //非固定表格,宽度不够时自动扩充

View File

@ -315,6 +315,12 @@ var TableHeader = function (_Component) {
var event = _utils.Event.getEvent(e), var event = _utils.Event.getEvent(e),
target = _utils.Event.getTarget(event); target = _utils.Event.getTarget(event);
_this.currentDome.setAttribute('draggable', false); //添加交换列效果 _this.currentDome.setAttribute('draggable', false); //添加交换列效果
var data = _this.getCurrentEventData(_this._dragCurrent);
if (!data) return;
if (!_this.props.onDrop) return;
// this.props.onDrop(event,target);
_this.props.onDrop(event, { dragSource: _this.currentObj, dragTarg: data });
}; };
_this.onDragEnter = function (e) { _this.onDragEnter = function (e) {
@ -340,8 +346,8 @@ var TableHeader = function (_Component) {
var data = _this.getCurrentEventData(_this._dragCurrent); var data = _this.getCurrentEventData(_this._dragCurrent);
if (!data) return; if (!data) return;
if (!_this.currentObj || _this.currentObj.key == data.key) return; if (!_this.currentObj || _this.currentObj.key == data.key) return;
if (!_this.props.onDrop) return; if (!_this.props.onDragEnd) return;
_this.props.onDrop(event, { dragSource: _this.currentObj, dragTarg: data }); _this.props.onDragEnd(event, { dragSource: _this.currentObj, dragTarg: data });
}; };
_this.onDragLeave = function (e) { _this.onDragLeave = function (e) {

View File

@ -51,7 +51,7 @@ function dragColumn(Table) {
return _column; return _column;
}; };
_this.onDrop = function (event, data) { _this.onDragEnd = function (event, data) {
var dragSource = data.dragSource, var dragSource = data.dragSource,
dragTarg = data.dragTarg; dragTarg = data.dragTarg;
var columns = _this.state.columns; var columns = _this.state.columns;
@ -76,14 +76,11 @@ function dragColumn(Table) {
newDate.title = da.title; newDate.title = da.title;
_newColumns.push(newDate); _newColumns.push(newDate);
}); });
// console.log(" onDrop-------columns--- ",columns);
_this.setState({ _this.setState({
columns: _newColumns //cloneDeep(columns) columns: _newColumns //cloneDeep(columns)
}); });
// console.log(" onDrop-------columns--- ",_newColumns); if (_this.props.onDragEnd) {
// console.log(columns === _newColumns); _this.props.onDragEnd(event, data, columns);
if (_this.props.onDrop) {
_this.props.onDrop(event, data, columns);
} }
}; };
@ -134,21 +131,13 @@ function dragColumn(Table) {
dragborder = _props.dragborder, dragborder = _props.dragborder,
draggable = _props.draggable, draggable = _props.draggable,
className = _props.className, className = _props.className,
columns = _props.columns, others = _objectWithoutProperties(_props, ['data', 'dragborder', 'draggable', 'className']);
onDragStart = _props.onDragStart,
onDragEnter = _props.onDragEnter,
onDragOver = _props.onDragOver,
onDrop = _props.onDrop,
others = _objectWithoutProperties(_props, ['data', 'dragborder', 'draggable', 'className', 'columns', 'onDragStart', 'onDragEnter', 'onDragOver', 'onDrop']);
return _react2["default"].createElement(Table, _extends({}, others, { return _react2["default"].createElement(Table, _extends({}, others, {
columns: this.state.columns, columns: this.state.columns,
data: data, data: data,
className: className + ' u-table-drag-border', className: className + ' u-table-drag-border',
onDragStart: this.onDragStart, onDragEnd: this.onDragEnd,
onDragOver: this.onDragOver,
onDrop: this.onDrop,
onDragEnter: this.onDragEnter,
draggable: draggable, draggable: draggable,
dragborder: dragborder dragborder: dragborder
})); }));

View File

@ -2,7 +2,7 @@
* *
* @title 拖拽改变列顺序 * @title 拖拽改变列顺序
* @parent 列操作-拖拽 Drag * @parent 列操作-拖拽 Drag
* @description 点击选择表头并左右拖拽可以改变表格列顺序onDrop方法是拖拽交换列后触发的回调函数注意固定列不可以交换 * @description 点击选择表头并左右拖拽可以改变表格列顺序 onDragEnd 方法是拖拽交换列后触发的回调函数注意固定列不可以交换
* demo1001 * demo1001
*/ */
import React, { Component } from 'react'; import React, { Component } from 'react';
@ -69,8 +69,16 @@ class Demo22 extends Component {
columns={columns} columns={columns}
data={data} data={data}
bordered bordered
draggable={true} draggable={true}
onDrop ={(event,data,columns)=>{ onDrop ={(event,data,columns)=>{
console.log("--拖拽交换列onDrop触发事件");
console.log("event.target:",event.target);
console.log("data:",data);
console.log("拖拽完成后的columns:",columns);
}}
onDragEnd ={(event,data,columns)=>{
console.log("--拖拽交换列后触发事件"); console.log("--拖拽交换列后触发事件");
console.log("event.target:",event.target); console.log("event.target:",event.target);
console.log("data:",data); console.log("data:",data);

File diff suppressed because one or more lines are too long

2
dist/demo.css vendored
View File

@ -291,7 +291,7 @@
.u-table-fixed-left .u-table-body-inner { .u-table-fixed-left .u-table-body-inner {
margin-right: -20px; margin-right: -20px;
padding-right: 20px; } padding-right: 20px; }
.u-table-fixed-header .u-table-fixed-left .u-table-body-inner { .u-table-fixed-header:not(.u-table-hide-header) .u-table-fixed-left .u-table-body-inner {
padding-right: 0px; } padding-right: 0px; }
.u-table-fixed-header .u-table-body-inner { .u-table-fixed-header .u-table-body-inner {
height: 100%; height: 100%;

2
dist/demo.css.map vendored

File diff suppressed because one or more lines are too long

85215
dist/demo.js vendored

File diff suppressed because one or more lines are too long

2
dist/demo.js.map vendored

File diff suppressed because one or more lines are too long

View File

@ -1,6 +1,6 @@
{ {
"name": "bee-table", "name": "bee-table",
"version": "2.1.14", "version": "2.2.0",
"description": "Table ui component for react", "description": "Table ui component for react",
"keywords": [ "keywords": [
"react", "react",

View File

@ -395,7 +395,7 @@ class Table extends Component {
} }
getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) { getHeader(columns, fixed, leftFixedWidth, rightFixedWidth) {
const { filterDelay, onFilterChange, onFilterClear, filterable, showHeader, expandIconAsCell, clsPrefix, onDragStart, onDragEnter, onDragOver, onDrop, draggable, const { filterDelay, onFilterChange, onFilterClear, filterable, showHeader, expandIconAsCell, clsPrefix, onDragStart, onDragEnter, onDragOver, onDrop,onDragEnd, draggable,
onMouseDown, onMouseMove, onMouseUp, dragborder, onThMouseMove, dragborderKey, minColumnWidth, headerHeight,afterDragColWidth,headerScroll ,bordered,onDropBorder,onDraggingBorder} = this.props; onMouseDown, onMouseMove, onMouseUp, dragborder, onThMouseMove, dragborderKey, minColumnWidth, headerHeight,afterDragColWidth,headerScroll ,bordered,onDropBorder,onDraggingBorder} = this.props;
const rows = this.getHeaderRows(columns); const rows = this.getHeaderRows(columns);
if (expandIconAsCell && fixed !== 'right') { if (expandIconAsCell && fixed !== 'right') {
@ -408,7 +408,7 @@ class Table extends Component {
} }
const trStyle = headerHeight&&!fixed ? { height: headerHeight } : (fixed ? this.getHeaderRowStyle(columns, rows) : null); const trStyle = headerHeight&&!fixed ? { height: headerHeight } : (fixed ? this.getHeaderRowStyle(columns, rows) : null);
let drop = draggable ? { onDragStart, onDragOver, onDrop, onDragEnter, draggable } : {}; let drop = draggable ? { onDragStart, onDragOver, onDrop,onDragEnd, onDragEnter, draggable } : {};
let dragBorder = dragborder ? { onMouseDown, onMouseMove, onMouseUp, dragborder, onThMouseMove, dragborderKey,onDropBorder,onDraggingBorder } : {}; let dragBorder = dragborder ? { onMouseDown, onMouseMove, onMouseUp, dragborder, onThMouseMove, dragborderKey,onDropBorder,onDraggingBorder } : {};
let contentWidthDiff = 0; let contentWidthDiff = 0;
//非固定表格,宽度不够时自动扩充 //非固定表格,宽度不够时自动扩充

View File

@ -492,6 +492,12 @@ class TableHeader extends Component {
let event = Event.getEvent(e) , let event = Event.getEvent(e) ,
target = Event.getTarget(event); target = Event.getTarget(event);
this.currentDome.setAttribute('draggable',false);//添加交换列效果 this.currentDome.setAttribute('draggable',false);//添加交换列效果
let data = this.getCurrentEventData(this._dragCurrent);
if(!data)return;
if(!this.props.onDrop)return;
// this.props.onDrop(event,target);
this.props.onDrop(event,{dragSource:this.currentObj,dragTarg:data});
}; };
@ -518,8 +524,8 @@ class TableHeader extends Component {
let data = this.getCurrentEventData(this._dragCurrent); let data = this.getCurrentEventData(this._dragCurrent);
if(!data)return; if(!data)return;
if (!this.currentObj || this.currentObj.key == data.key) return; if (!this.currentObj || this.currentObj.key == data.key) return;
if(!this.props.onDrop)return; if(!this.props.onDragEnd)return;
this.props.onDrop(event,{dragSource:this.currentObj,dragTarg:data}); this.props.onDragEnd(event,{dragSource:this.currentObj,dragTarg:data});
} }

View File

@ -43,7 +43,7 @@ export default function dragColumn(Table) {
return data return data
} }
onDrop=(event,data)=>{ onDragEnd=(event,data)=>{
let {dragSource,dragTarg} = data; let {dragSource,dragTarg} = data;
let {columns} = this.state; let {columns} = this.state;
let sourceIndex = -1,targetIndex = -1; let sourceIndex = -1,targetIndex = -1;
@ -65,14 +65,11 @@ export default function dragColumn(Table) {
newDate.title = da.title; newDate.title = da.title;
_newColumns.push(newDate); _newColumns.push(newDate);
}); });
// console.log(" onDrop-------columns--- ",columns);
this.setState({ this.setState({
columns:_newColumns//cloneDeep(columns) columns:_newColumns//cloneDeep(columns)
}); });
// console.log(" onDrop-------columns--- ",_newColumns); if(this.props.onDragEnd){
// console.log(columns === _newColumns); this.props.onDragEnd(event,data,columns);
if(this.props.onDrop){
this.props.onDrop(event,data,columns);
} }
} }
@ -86,11 +83,6 @@ export default function dragColumn(Table) {
dragborder, dragborder,
draggable, draggable,
className, className,
columns,
onDragStart,
onDragEnter,
onDragOver,
onDrop,
...others ...others
} = this.props; } = this.props;
return ( return (
@ -99,10 +91,7 @@ export default function dragColumn(Table) {
columns={this.state.columns} columns={this.state.columns}
data={data} data={data}
className={`${className} u-table-drag-border`} className={`${className} u-table-drag-border`}
onDragStart={this.onDragStart} onDragEnd={this.onDragEnd}
onDragOver={this.onDragOver}
onDrop={this.onDrop}
onDragEnter={this.onDragEnter}
draggable={draggable} draggable={draggable}
dragborder={dragborder} dragborder={dragborder}
/>) />)