Openinula-VTable
@visactor/openinula-vtable包是为了方便在 Openinula 环境更加方便使用 VTable 所进行的 Openinula 封装。该组件主要对 VTable 表格做 Openinula 组件化的封装,相关的配置项均与 VTable 一致。
快速开始
环境要求
确保你的环境中安装了node,npm以及Openinula,并且满足以下版本要求:
- node 10.12.0+
- npm 6.4.0+
- openinula 0.1.2-SNAPSHOT+
安装
使用包管理器安装
# 使用 npm 安装 npm install @visactor/openinula-vtable # 使用 yarn 安装 yarn add @visactor/openinula-vtable
引入 Openinula-VTable
推荐使用 npm 包引入
import { ListTable } from '@visactor/openinula-vtable';
绘制一个简单的列表
你可以像使用标准的 Openinula 组件一样,使用通过@visactor/openinula-vtable导入的ListTable组件。
以下是一个简单列表示例代码:
import Openinula from 'openinula';
import OpeninulaDOM from 'openinula-dom/client';
import { ListTable } from '@visactor/openinula-vtable';
const option = {
columns: [
{
field: '0',
title: 'name'
},
{
field: '1',
title: 'age'
},
{
field: '2',
title: 'gender'
},
{
field: '3',
title: 'hobby'
}
],
records: new Array(1000).fill(['John', 18, 'male', '🏀'])
};
Inula.render(<ListTable option={option} height={'500px'} />, document.getElementById('root'));
参考demo
使用方式
Openinula-VTable 提供两种风格的组件供开发者使用,分别是统一标签与语法化标签。
统一标签
统一标签是指是使用一个 Table 标签,接收一个完整的option配置,如果项目中已经使用了 VTable ,这种方式可以快速使用 Openinula-VTable。上面的例子就是一个使用统一标签的demo。
与 VTable 相同 Openinula-VTable 提供三种表格类型:
- ListTable: 列表表格,用于展示列表数据 demo
- PivotTable: 透视表格,用于展示交叉透视数据 demo
- PivotChart: 透视图,用于展示交叉透视数据并以图表方式展示 demo
这三种 Openinula 组件,其 props 定义如下:
interface VTableProps extends EventsProps {
option: ITableOption;
records?: any;
width?: number;
height?: number;
onReady?: (instance: VTable, isInitial: boolean) => void;
}
EventsProps 的定义参考事件绑定章节
onReady 是一个内置的回调事件,会在表格渲染或更新时触发,其入参分别代表表格实例对象,以及是否初次渲染。
Openinula-VTable 统一标签几乎是 VTable 的对等功能,可以方便开发者进行 Openinula 版本的迁移,并且从社区或示例中心获得的 option 可以直接通过这种方式使用,开发者几乎没有额外的学习成本。
语法化标签
语法化标签是指 Openinula-VTable 将表格中的部分组件封装为 Openinula 组件导出给开发者,开发者可以通过更加语义化、更接近原生 Openinula 声明的方式来定义表格。需要说明的是语法化标签的定义内容,在多数场景下都是可以和表格描述option进行相互转化的。
需要注意的是:虽然图表在定义上是通过 Openinula 组件的形式进行声明的,但实际实现中并不是将其解析为 DOM 进行渲染,因此假如使用审查元素时并不能看到各个图表组件对应的 DOM。
ListTable
ListTable 接受的 props 属性与 option 一致,ListTable 中的子组件如下
- ListColumn: 列表列,同 option 中的 columns 的定义一致 api
import { ListTable, ListColumn } from '../../../src';
function App() {
// ......
return (
<ListTable records={records}>
<ListColumn field={'0'} title={'名称'} />
<ListColumn field={'1'} title={'年龄'} />
<ListColumn field={'2'} title={'性别'} />
<ListColumn field={'3'} title={'爱好'} />
</ListTable>
);
}
语法化标签 demo:demo
PivotTable&PivotChart
PivotTable&PivotChart 接受的 props 属性与 option 一致,子组件如下:
- PivotColumnDimension: 列上的维度配置,同 option 中的 columns 的定义一致 api
- PivotRowDimension: 行上的维度配置,同 option 中的 rows 的定义一致 api
- PivotIndicator: 指标配置,同 option 中的 indicators 的定义一致 api
- PivotColumnHeaderTitle: 列表头标题配置,同 option 中的 columnHeaderTitle 的定义一致 api
- PivotRowHeaderTitle: 行头标题配置,同 option 中的 rowHeaderTitle 的定义一致 api
- PivotCorner: 角头配置,同 option 中的 corner 的定义一致 api
return ( <PivotTable // ...... > <PivotColumnHeaderTitle // ...... /> <PivotColumnDimension // ...... /> <PivotColumnDimension // ...... /> <PivotRowDimension // ...... /> <PivotRowDimension // ...... /> <PivotIndicator // ...... /> <PivotIndicator // ...... /> <PivotCorner // ...... /> </PivotTable> );
语法化标签 demo:PivotTable demo PivotChart demo
表格外组件
表格外组件目前支持:
<PivotTable> // ...... <Menu // ...... /> <Tooltip // ...... /> </PivotTable>
事件绑定
统一标签或是语法化表格标签最外层表格组件,其 Props 上都继承了表格的事件处理回调 EventsProps。
EventsProps 的定义如下:
interface EventsProps {
onClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['click_cell']>;
onDblClickCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dblclick_cell']>;
onMouseDownCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousedown_cell']>;
onMouseUpCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseup_cell']>;
onSelectedCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['selected_cell']>;
onKeyDown?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['keydown']>;
onMouseEnterTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_table']>;
onMouseLeaveTable?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_table']>;
onMouseMoveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mousemove_cell']>;
onMouseEnterCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_cell']>;
onMouseLeaveCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_cell']>;
onContextMenuCell?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['contextmenu_cell']>;
onContextMenuCanvas?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['contextmenu_canvas']>;
onResizeColumn?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column']>;
onResizeColumnEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['resize_column_end']>;
onChangeHeaderPosition?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['change_header_position']>;
onSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['sort_click']>;
onFreezeClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['freeze_click']>;
onScroll?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['scroll']>;
onDropdownMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_click']>;
onMouseOverChartSymbol?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseover_chart_symbol']>;
onDragSelectEnd?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drag_select_end']>;
onDropdownIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_icon_click']>;
onDropdownMenuClear?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['dropdown_menu_clear']>;
onTreeHierarchyStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['tree_hierarchy_state_change']>;
onShowMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['show_menu']>;
onHideMenu?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['hide_menu']>;
onIconClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['icon_click']>;
onLegendItemClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_click']>;
onLegendItemHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_hover']>;
onLegendItemUnHover?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_item_unHover']>;
onLegendChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['legend_change']>;
onMouseEnterAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseenter_axis']>;
onMouseLeaveAxis?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['mouseleave_axis']>;
onCheckboxStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['checkbox_state_change']>;
onRadioStateChange?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['radio_state_change']>;
onAfterRender?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['after_render']>;
onInitialized?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['initialized']>;
// pivot table only
onPivotSortClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['pivot_sort_click']>;
onDrillMenuClick?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['drillmenu_click']>;
// pivot chart only
onVChartEventType?: EventCallback<TYPES.TableEventHandlersEventArgumentMap['vchart_event_type']>;
}
事件使用示例:
function App() { const option = { // ...... }; return ( <ListTable option={option} onClickCell={(...arg: any) => { console.log('onClickCell', ...arg); }} /> ); }
事件详细描述参考:事件介绍