增加时间类型

This commit is contained in:
huayj 2019-08-26 16:48:06 +08:00
parent cb3390688b
commit fccea4eb05
2 changed files with 25 additions and 4 deletions

View File

@ -134,9 +134,12 @@ import 'bee-table/build/Table.css';
| $\color{red}{*}$bgColor | 列背景颜色 | string | - | | $\color{red}{*}$bgColor | 列背景颜色 | string | - |
| $\color{red}{*}$titleAlign | 标题对齐方式 | 'left'\|'center'\|'right' | 'left' | | $\color{red}{*}$titleAlign | 标题对齐方式 | 'left'\|'center'\|'right' | 'left' |
| $\color{red}{*}$contentAlign | 内容对齐方式 | 'left'\|'center'\|'right' | 'left' | | $\color{red}{*}$contentAlign | 内容对齐方式 | 'left'\|'center'\|'right' | 'left' |
| $\color{red}{*}$required | 必填项,展示红色星号 | bool | false | | $\color{red}{*}$required | 必填项,列标题展示红色星号 | bool | false |
#### [新增]fieldType #### [新增]fieldType
fieldType属性控制了不同类型数据的渲染方式,其优先级低于render属性。目前已有`string`,`number`,`currency`,`bool`,`link`类型,支持自定义配置。
fieldType属性控制了不同类型数据的渲染方式,其优先级低于render属性。目前已有`string`,`number`,`currency`,`bool`,`link`,`date`类型,支持自定义配置(`string`类型为默认类型)。
- numberConfig - numberConfig
|具体属性|说明|类型|默认值| |具体属性|说明|类型|默认值|
@ -179,6 +182,15 @@ fieldType属性控制了不同类型数据的渲染方式,其优先级低于rend
*desc和descIndex属性相比desc优先级更高* *desc和descIndex属性相比desc优先级更高*
- dateConfig
|具体属性|说明|类型|默认值|
|:--|:---|:--|:---|
|moment|传入的moment对象,必需|object|-|
|format|渲染的时间格式|string|'YYYY-MM-DD'|
*需要单独安装[moment.js](http://momentjs.cn/),并将moment对象传入*
### 高阶函数 ### 高阶函数
Table内部封装了七个高阶组件接收基础 Table 组件作为输入,输出一个新的复杂 Table 组件。高阶组件让代码更具有复用性、逻辑性与抽象特征。 Table内部封装了七个高阶组件接收基础 Table 组件作为输入,输出一个新的复杂 Table 组件。高阶组件让代码更具有复用性、逻辑性与抽象特征。

View File

@ -108,7 +108,12 @@ class TableCell extends Component{
</span>; </span>;
} }
// 渲染时间类型
renderDate = ( data, config={}) => {
const { moment, format } = config;
if(!moment)return data;
return moment(data).format(format || 'YYYY-MM-DD');
}
render() { render() {
const { record, indentSize, clsPrefix, indent, const { record, indentSize, clsPrefix, indent,
@ -164,6 +169,10 @@ class TableCell extends Component{
text = this.renderNumber(text, {...config,...column.numberConfig}, column.width); text = this.renderNumber(text, {...config,...column.numberConfig}, column.width);
break; break;
} }
case 'date':{
text = this.renderDate(text, column.dateConfig);
break;
}
default : { default : {
break; break;
} }
@ -198,7 +207,7 @@ class TableCell extends Component{
else if(column.textAlign){ else if(column.textAlign){
className = className+` text-${column.textAlign}`; className = className+` text-${column.textAlign}`;
} }
if(typeof text == 'string' && bodyDisplayInRow){ if((typeof text == 'string' || typeof text === 'number') && bodyDisplayInRow){
title = text title = text
} }
if(expandIcon && expandIcon.props.expandable){ if(expandIcon && expandIcon.props.expandable){