大数据在expanded场景下的使用

This commit is contained in:
wanghaoo 2018-12-18 15:42:31 +08:00
commit 6fa264e5b9
10 changed files with 180 additions and 66 deletions

View File

@ -1,3 +1,8 @@
<a name="1.6.16"></a>
## [1.6.16](https://github.com/tinper-bee/bee-table/compare/v1.6.15...v1.6.16) (2018-12-17)
<a name="1.6.15"></a> <a name="1.6.15"></a>
## [1.6.15](https://github.com/tinper-bee/bee-table/compare/v1.6.14...v1.6.15) (2018-12-15) ## [1.6.15](https://github.com/tinper-bee/bee-table/compare/v1.6.14...v1.6.15) (2018-12-15)
@ -164,7 +169,7 @@
<a name="1.5.1"></a> <a name="1.5.1"></a>
## [1.5.1](https://github.com/tinper-bee/bee-table/compare/v1.5.0...v1.5.1) (2018-11-18) ## [1.5.1](https://github.com/tinper-bee/bee-table/compare/v1.5.0...v1.5.1) (2018-11-19)

89
build/lib/bigData.js Normal file
View File

@ -0,0 +1,89 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
exports["default"] = bigData;
var _react = require("react");
var _react2 = _interopRequireDefault(_react);
var _propTypes = require("prop-types");
var _propTypes2 = _interopRequireDefault(_propTypes);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); }
var propTypes = {
rowsInView: _propTypes2["default"].number.isRequired
};
var defaultProps = {
data: undefined,
height: 40, //默认行高
rowsInView: 25
};
function bigData(Table) {
return function (_Component) {
_inherits(BigData, _Component);
function BigData(props) {
_classCallCheck(this, BigData);
var _this = _possibleConstructorReturn(this, _Component.call(this, props));
_this.state = {
currentIndex: 0,
scrollLeft: 0,
scrollTop: 0
};
_this.cachedRowHeight = [];
_this.lastScrollTop = 0;
return _this;
}
/**
*获取数据区高度
*
*
**/
BigData.prototype.getContentHeight = function getContentHeight() {
if (!this.props.data) return 0;
return this.getSumHeight(0, this.props.data.length);
};
BigData.prototype.getSumHeight = function getSumHeight(start, end) {
var rowHeight = this.props.rowHeight;
var height = 0;
for (var i = start; i < end; i++) {
height += this.cachedRowHeight[i] || rowHeight;
}
return height;
};
BigData.prototype.getData = function getData() {};
BigData.prototype.render = function render() {
return _react2["default"].createElement(Table, _extends({}, this.props, { data: this.getData }));
};
return BigData;
}(_react.Component);
BigData.defaultProps = defaultProps;
BigData.propTypes = propTypes;
}
module.exports = exports["default"];

View File

@ -37,7 +37,7 @@ const columns = [
); );
} }
}, },
{ id: "123", title: "性别", dataIndex: "b", key: "b", width: 200}, { id: "123", title: "性别", dataIndex: "b", key: "b", width: 60},
{ title: "年龄", dataIndex: "c", key: "c", width: 200 }, { title: "年龄", dataIndex: "c", key: "c", width: 200 },
{ {
title: "操作", title: "操作",
@ -63,7 +63,11 @@ const columns = [
]; ];
const data = [ ...new Array(10000) ].map((e, i) => { const data = [ ...new Array(10000) ].map((e, i) => {
return { a: i + 'a', b: i + 'b', c: i + 'c', d: i + 'd', key: i }; const rs = { a: i + 'a', b: i + 'b', c: i + 'c', d: i + 'd', key: i };
if(i%3==0){
rs.b = '我的性别lalallalalal我的性别lalallalalal我的性别lalallalalal女';
}
return rs;
}) })

View File

@ -58,11 +58,10 @@ const innerColumns = [
]; ];
const data16 = [ const data16 = [ ...new Array(10000) ].map((e, i) => {
{ a: "令狐冲", b: "男", c: 41, d: "操作", key: "1" }, return { a: i + 'a', b: i + 'b', c: i + 'c', d: i + 'd', key: i };
{ a: "杨过", b: "男", c: 67, d: "操作", key: "2" }, })
{ a: "郭靖", b: "男", c: 25, d: "操作", key: "3" }
];
class Demo31 extends Component { class Demo31 extends Component {
@ -98,7 +97,8 @@ class Demo31 extends Component {
}) })
}else{ }else{
new_obj[record.key] = [ new_obj[record.key] = [
{ a: "令狐冲", b: "男", c: 41, d: "操作", key: "1" } { a: "令狐冲", b: "男", c: 41, d: "操作", key: "1" },
{ a: "菲菲", b: "nv", c: 67, d: "操作", key: "2" }
] ]
this.setState({ this.setState({
data_obj:new_obj data_obj:new_obj

File diff suppressed because one or more lines are too long

107
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": "1.6.15", "version": "1.6.16",
"description": "Table ui component for react", "description": "Table ui component for react",
"keywords": [ "keywords": [
"react", "react",

View File

@ -499,6 +499,7 @@ class Table extends Component {
) )
} }
const lazyCurrentIndex = props.lazyLoad && props.lazyLoad.currentIndex ?props.lazyLoad.currentIndex :0; const lazyCurrentIndex = props.lazyLoad && props.lazyLoad.currentIndex ?props.lazyLoad.currentIndex :0;
let expandedContentHeight = 0;
for (let i = 0; i < data.length; i++) { for (let i = 0; i < data.length; i++) {
const record = data[i]; const record = data[i];
const key = this.getRowKey(record, i); const key = this.getRowKey(record, i);
@ -507,6 +508,7 @@ class Table extends Component {
let expandedRowContent; let expandedRowContent;
if (expandedRowRender && isRowExpanded) { if (expandedRowRender && isRowExpanded) {
expandedRowContent = expandedRowRender(record, i, indent); expandedRowContent = expandedRowRender(record, i, indent);
expandedContentHeight = parseInt(expandedRowContent.props.style?expandedRowContent.props.style.height:0);
} }
//只有当使用expandedRowRender参数的时候才去识别isHiddenExpandIcon隐藏行展开的icon //只有当使用expandedRowRender参数的时候才去识别isHiddenExpandIcon隐藏行展开的icon
if (expandedRowRender && typeof props.haveExpandIcon == 'function') { if (expandedRowRender && typeof props.haveExpandIcon == 'function') {
@ -576,6 +578,7 @@ class Table extends Component {
store={this.store} store={this.store}
fixed={fixed} fixed={fixed}
lazyCurrentIndex={lazyCurrentIndex} lazyCurrentIndex={lazyCurrentIndex}
expandedContentHeight={expandedContentHeight}
/> />
); );
this.treeRowIndex++; this.treeRowIndex++;

View File

@ -78,9 +78,9 @@ class TableRow extends Component{
setRowHeight() { setRowHeight() {
const { setRowHeight } = this.props const { setRowHeight , expandedContentHeight} = this.props
if (!setRowHeight || !this.element) return if (!setRowHeight || !this.element) return
setRowHeight(this.element.clientHeight + this.expandHeight, this.props.index) setRowHeight(this.element.clientHeight + expandedContentHeight, this.props.index)
} }
onRowClick(event) { onRowClick(event) {