Skip to content

Table 表格

基于element-plus table组件的二次封装。简化表格配置。

基础用法

树表格

功能表格

Table 属性

属性说明类型是否拓展默认值
data表数据Array
columns列配置TableColumn[]
heighttable 的高度。 默认为自动高度, Table 的高度会受控于外部样式。enum
max-heighttable 的最大高度enum
stripe是否为斑马纹 tablebooleanfalse
border是否带有纵向边框booleantrue
sizeTable 的尺寸enum
fit列的宽度是否自撑开booleantrue
show-header是否显示表头booleantrue
highlight-current-row是否要高亮当前行booleanfalse
current-row-key当前行的 key,只写属性enum
row-class-name行的 className 的回调方法,也可以使用字符串为所有行设置一个固定的 className。enum
row-style行的 style 的回调方法,可以使用固定的 Object 为所有行设置一样的 Style。enum
cell-class-name单元格的 className 的回调方法,可以为所有单元格设置一个固定的 className。enum
cell-style单元格的 style 的回调方法,可以使用固定的 Object 为所有单元格设置一样的 Style。enum
header-row-class-name表头行的 className 的回调方法,可以为所有表头行设置一个固定的 className。enum
header-row-style表头行的 style 的回调方法,可以使用固定的 Object 为所有表头行设置一样的 Style。enum
header-cell-class-name表头单元格的 className 的回调方法,可以为所有表头单元格设置一个固定的 className。enum
header-cell-style表头单元格的 style 的回调方法,可以使用固定的 Object 为所有表头单元格设置一样的 Style。enum
row-key行数据的 Key,用来优化 Table 的渲染; 在使用reserve-selection功能与显示树形数据时,该属性是必填的。enumid
empty-text空数据时显示的文本内容, 也可以通过插槽设置stringNo Data
default-expand-all是否默认展开所有行,当 Table 包含展开行存在或者为树形表格时有效booleanfalse
expand-row-keys可以通过该属性设置 Table 目前的展开行,需要设置 row-key 属性才能使用,该属性为展开行的 keys 数组。Array
default-sort默认的排序列的 prop 和顺序。 prop 属性指定默认的排序的列,order 指定默认排序的顺序objectprop设定,order默认ascending
tooltip-effect溢出的 tooltip 的 effectenumdark
tooltip-options溢出 tooltip 的选项,参见下述 tooltip 组件objectobject
show-summary是否在表尾显示合计行booleanfalse
sum-text显示摘要行第一列的文本stringSum
summary-method自定义的合计计算方法Function
span-method合并行或列的计算方法Function
select-on-indeterminate在多选表格中,当仅有部分行被选中时,点击表头的多选框时的行为。 若为 true,则选中所有行;若为 false,则取消选择所有行booleantrue
indent展示树形数据时,树节点的缩进number16
lazy是否懒加载子节点数据booleanfalse
load加载子节点数据的函数,lazy 为 true 时生效Function
tree-props渲染嵌套数据的配置选项objectobject
table-layout设置表格单元、行和列的布局方式enumfixed
scrollbar-always-on总是显示滚动条booleanfalse
show-overflow-tooltip是否隐藏额外内容并在单元格悬停时使用 Tooltip 显示它们。这将影响全部列的展示enum
flexible确保主轴的最小尺寸,以便不超过内容booleanfalse

TableColumn 属性

属性说明类型是否拓展默认值
type对应列的类型。 如果设置了 selection 则显示多选框; 如果设置了 index 则显示该行的索引(从 1 开始计算); 如果设置了 expand 则显示为一个可展开的按钮enumdefault
index如果设置了 type=index,可以通过传递 index 属性来自定义索引enum
label显示的标题string
column-keycolumn 的 key, 如果需要使用 filter-change 事件,则需要此属性标识是哪个 column 的筛选条件string
prop字段名称 对应列内容的字段名, 也可以使用 property 属性string
width对应列的宽度enum''
min-width对应列的最小宽度, 与 width 的区别是 width 是固定的,min-width 会把剩余宽度按比例分配给设置了 min-width 的列enum''
fixed列是否固定在左侧或者右侧。 true 表示固定在左侧enumfalse
render-header列标题 Label 区域渲染使用的 FunctionFunction
sortable对应列是否可以排序, 如果设置为 'custom',则代表用户希望远程排序,需要监听 Table 的 sort-change 事件enumfalse
sort-method指定数据按照哪个属性进行排序,仅当 sortable 设置为 true 的时候有效。 应该如同 Array.sort 那样返回一个 NumberFunction
sort-by指定数据按照哪个属性进行排序,仅当 sortable 设置为 true 且没有设置 sort-method 的时候有效。 如果 sort-by 为数组,则先按照第 1 个属性排序,如果第 1 个相等,再按照第 2 个排序,以此类推enum
sort-orders数据在排序时所使用排序策略的轮转顺序,仅当 sortable 为 true 时有效。 需传入一个数组,随着用户点击表头,该列依次按照数组中元素的顺序进行排序object['ascending', 'descending', null]
resizable对应列是否可以通过拖动改变宽度(需要在 el-table 上设置 border 属性为真)booleantrue
formatter用来格式化内容Function
show-overflow-tooltip当内容过长被隐藏时显示 tooltipenumundefined
align对齐方式enumcenter
header-align表头对齐方式, 若不设置该项,则使用表格的对齐方式enumcenter
class-name列的 classNamestring
label-class-name当前列标题的自定义类名string
selectable仅对 type=selection 的列有效,类型为 Function,Function 的返回值用来决定这一行的 CheckBox 是否可以勾选Function
reserve-selection数据刷新后是否保留选项,仅对 type=selection 的列有效, 请注意, 需指定 row-key 来让这个功能生效。booleanfalse
filters数据过滤的选项, 数组格式,数组中的元素需要有 text 和 value 属性。 数组中的每个元素都需要有 text 和 value 属性。object
filter-placement过滤弹出框的定位enum
filter-class-name过滤弹出框的 classNamestring
filter-multiple数据过滤的选项是否多选booleantrue
filter-method数据过滤使用的方法, 如果是多选的筛选项,对每一条数据会执行多次,任意一次返回 true 就会显示。function
filtered-value选中的数据过滤项,如果需要自定义表头过滤的渲染方式,可能会需要此属性。object

插槽

插槽名说明类型
${prop}数据列插槽,适用于复杂的数据处理object
header-${prop}通用的表头插槽,通过columns 项的prop进行关联object
append插入至表格最后一行之后的内容-
empty当数据为空时自定义的内容-

事件

事件名说明类型是否拓展
select当用户手动勾选数据行的 Checkbox 时触发的事件Function
select-all当用户手动勾选全选 Checkbox 时触发的事件Function
selection-change当选择项发生变化时会触发该事件Function
cell-mouse-enter当单元格 hover 进入时会触发该事件Function
cell-mouse-leave当单元格 hover 退出时会触发该事件Function
cell-click当某个单元格被点击时会触发该事件Function
cell-dblclick当某个单元格被双击击时会触发该事件Function
cell-contextmenu当某个单元格被鼠标右键点击时会触发该事件Function
row-click当某一行被点击时会触发该事件Function
row-contextmenu当某一行被鼠标右键点击时会触发该事件Function
row-dblclick当某一行被双击时会触发该事件Function
header-click当某一列的表头被点击时会触发该事件Function
header-contextmenu当某一列的表头被鼠标右键点击时触发该事件Function
sort-change当表格的排序条件发生变化的时候会触发该事件Function
filter-changecolumn 的 key, 如果需要使用 filter-change 事件,则需要此属性标识是哪个 column 的筛选条件Function
current-change当表格的当前行发生变化的时候会触发该事件,如果要高亮当前行,请打开表格的 highlight-current-row 属性Function
header-dragend当拖动表头改变了列的宽度的时候会触发该事件Function
expand-change当用户对某一行展开或者关闭的时候会触发该事件(展开行时,回调的第二个参数为 expandedRows;树形表格时第二参数为 expanded)Function

Table Exposes

方法名说明类型
getTableRef获取el-table 实例, El-Table Exposes 下的方法均需在该方法获取的实例上调用Function

El-Table Exposes

方法名说明类型
clearSelection用于多选表格,清空用户的选择Function
getSelectionRows返回当前选中的行Function
toggleRowSelection用于多选表格,切换某一行的选中状态, 如果使用了第二个参数,则可直接设置这一行选中与否Function
toggleAllSelection用于多选表格,切换全选和全不选Function
toggleRowExpansion用于可扩展的表格或树表格,如果某行被扩展,则切换。 使用第二个参数,您可以直接设置该行应该被扩展或折叠。Function
setCurrentRow用于单选表格,设定某一行为选中行, 如果调用时不加参数,则会取消目前高亮行的选中状态。Function
clearSort用于清空排序条件,数据会恢复成未排序的状态Function
clearFilter传入由columnKey 组成的数组以清除指定列的过滤条件。 如果没有参数,清除所有过滤器Function
doLayout对 Table 进行重新布局。 当表格可见性变化时,您可能需要调用此方法以获得正确的布局Function
sort手动排序表格。 参数 prop 属性指定排序列,order 指定排序顺序。Function
scrollTo滚动到一组特定坐标Function
setScrollTop设置垂直滚动位置Function
setScrollLeft设置水平滚动位置Function
columns el^2.7.6获取表列的 contextarray

基于 MIT 许可发布