@wangankeji/eltable-wrapper
v1.4.10
Published
ElementUI ElTable和ElPagination 包装组件
Downloads
10
Maintainers
Readme
ElTableWrapper
此组件封装了 element-ui
中的 ElTable
和 ElPagination
组件,以提供表格与分页一体化的展示效果。
注: 后将此组件
ElTableWrapper
统称为组件
组件支持多种分页方式,点此查看
组件支持单元格编辑,点此查看
原
@hyjiacan/eltable-wrapper
安装
npm install @wangankeji/eltable-wrapper
或
yarn add @wangankeji/eltable-wrapper
快速上手
main.js
import Vue from 'vue'
import ElTableWrapper from '@wangankeji/ElTableWrapper'
import '@wangankeji/eltable-wrapper/lib/eltable-wrapper.css'
// 设置组件的默认值
const defaults = {
// ajax请求函数
ajax: (e) => {
},
// ajax请求method
method: 'get',
// 每页显示的数据量
size: 10,
// 分页类型
type: 'l'
}
Vue.use(ElTableWrapper, defaults)
<el-table-wrapper
url="/path/to/url"
:params="{p0: 1}"
@ajax-error="onAjaxError"
>
<el-table-column type="selection"></el-table-column>
<el-table-column prop="id"></el-table-column>
<el-table-column prop="name"></el-table-column>
</el-table-wrapper>
<script>
export default {
methods: {
onAjaxError(e) {
console.error(e)
}
}
}
</script>
属性
可以通过以下方式指定组件属性的默认值:
import Vue from 'vue'
import ElTableWrapper from '@wangankeji/ElTableWrapper'
// 设置组件的默认值
const defaults = {
// ajax请求函数
ajax: (e) => {
},
// ajax请求method
method: 'get',
// 每页显示的数据量
size: 10,
// 分页类型
type: 'l'
}
Vue.use(ElTableWrapper, defaults)
公共属性
|名称|类型|默认值|描述|
|---|---|---|---|
|type|String|s|分页方式,可选值: l
(本地分页), i
(增量分页), s
(服务器分页),去看看分页方式|
|auto-height|Boolean|false|是否自动调整高度,设置为false
时会设置高度撑满父容器|
|custom-class|String|-|自定义的样式类|
|pager-position|String|bottom|分页条位置,可选值为 bottom
top
both
|
|header-size|String/Number|48|header
高度,单位为px
|
|footer-size|String/Number|40|footer
高度,单位为px
|
|footer-target|String/HTMLElement|-|自定义 footer
的挂载元素,设置此值可以将其挂载到任意位置。可以是元素对象或选择器 since 1.2.0
|
|show-footer|Boolean|true|是否显示footer部分。当指定下方的 pager 或 footer 插槽时,也会显示 since 0.8.0
|
|v-model|Object/Array|-|获取选中的项,暂不支持设置初始化选中值,若要设置初始化选中值,请使用方法 select
since 0.8.0
|
|selection|String|-|指示表格选择模式,可选值为: 空, single
, multiple
,需要启用单选时,需要指定值为single
,当表格列中指定了 type="selection"
时,会覆盖此值为 multiple
|
|show-selection-info|Boolean|true|在多选模式下,是否在分页条左侧显示选中项信息 since 1.1.9
|
|empty-selection-text|String|未选择项|当未选择数据项时,在选中信息处显示的提示文本 since 1.2.1
|
|toggle-on-row-click|Boolean|false|是否在行被点击时切换行的选中状态(仅在多选时有效)since 0.7.0
|
|row-click-interceptor|Function|-|点击行时的拦截器,返回 false 表示拦截点击事件。一般配合 toggle-on-row-click
属性使用 since 1.1.8
|
|advance-selection|Boolean|false|是否启用高级选择,启用时支持跨页页面选择|
|id-field|String/Array/Function|id|数据项的标识字段,若标识不在顶层,则使用数组传递,也可以传入一个函数,函数接收一个行对象,函数的返回值将作为标识|
|size|String/Number|10|每页显示的数据量|
|sizes|Array|-|切换每页显示数据量的列表|
|index|String/Number|1|默认显示的页码|
|show-pager-summary|Boolean|true|是否显示总数据量|
|check-field|String|-|设置行的选中字段,若不为空,那么行数据的此字段会被标记为 true/false
(仅在多选时有效)since 0.7.0
|
ElTable
的原生属性支持见 ElTable支持的属性ElTable
的原生事件支持见 ElTable支持的事件ElPagination
的原生属性支持见 ElPagination支持的属性
多层的
id-field
使用数组而不是字符串,是为了便于处理某些字段中包含特殊字符(甚至是.
符号)的情形
id-field
为函数的情形:
某些情况下,数据的主键并不只是一个字段,而是多个字段组合形成。此时使用函数能够快速处理:
// 接收的参数为行数据对象
function idFieldGetter(row) {
// 返回值会作为数据的标识
return `${row.field1}_${row.field2}
}
check-field
示例:
<template>
<el-table-wrapper check-field="isSelected" selection="multiple">
<template v-slot="{row}">
{{row.isSelected}}
</template>
</el-table-wrapper>
</template>
check-field
通常与toggle-on-row-click
属性联合使用,以在不使用checkbox
(选择列)的时候用来标记行的选中状态。 为保证数据能正确响应,最好在数据加载到表格前就加上check-field
(即上例中的_isSelected
属性 ) 字段。
AJAX属性
|名称|类型|默认值|描述|
|---|---|---|---|
|ajax|function|-|向服务器发送ajax请求的方法,需要返回一个 Promise
对象。当 type
为i
或 s
时是必须的|
|url|String|-|向服务器请求数据的url|
|method|String|get|向服务器请求数据的method|
|ajax-param-*|any|-|在发送ajax请求时,附带传递给ajax方法的参数。详细见下方描述|
|ajax-option|Object|{}|在发送ajax请求时,附带传递给ajax方法的选项。其值可以分开设置,详细见下方描述|
|ajax-delay|Number|500|发送ajax请求的延时,单位为毫秒,设置此值以降低请求被频繁触发|
|params|Object|-|向服务器请求数据的参数|
|param-size|String|pageSize|向服务器发送请求时,数据量参数名|
|response-handler|Function|-|设置当服务器返回数据后,预处理函数,处理后的数据通过返回值提交|
|auto-load|Boolean|true|在使用服务器数据源时,是否在挂载后自动加载数据|
|check-params|Function(params [,changed])|-|在组件向服务器发起请求前,可以通过此函数检查参数是否正确,将新的参数作为返回值,返回false
以阻止继续执行,返回true
或undefined
使用原参数继续执行|
|load-when-params-change|Boolean|false|是否在ajax参数改变时自动重新加载数据(此时会监听params
变化)|
|loading|Boolean|false|是否显示loading状态|
|loading-text|Boolean|false|显示loading状态时的文本|
|loading-icon|Boolean|false|显示loading状态时的图标|
|loading-color|Boolean|false|显示loading状态时的背景色|
|auto-reset-scroll|Boolean|true|是否在加载数据后自动将滚动条定位到顶部,设置为 false
时可以调用 resetScroll()
|
check-params
的第二个参数,仅在params
改变时,自动重新请求时有效,其描述了参数的变化, 更多信息参考 deep-diff。 可以在check-params
中通过判断changed
的值,以阻止某些参数变化时自动重新加载
ajax-param-*
Since 1.2.0
用于向 AJAX 请求指定参数,这些参数会被 params
中相同属性的值覆盖。
如:
:ajax-param-size="20"
=>{size: 20}
ajax-param-type="normal"
=>{type: 'normal'}
ajax-param-data-prop="xxxxx"
=>{data: {prop: 'xxxxx'}}
ajax-option
这通常是一个对象。用于传递给 ajax 函数,其格式如下:
ajax({
option: {...}
})
上面代码中 option
就是 ajax-option
的值。
但有时候我们仅仅需要设置其中的一个或几个属性, 此时再写一个对象就显示繁琐了。于是,就支持了以下的简写:
<el-table-wrapper
:ajax-option-foo="true"
:ajax-option-bar="false"
ajax-option-foobar-fool="ish"
></el-table-wrapper>
以上写法等价于
<el-table-wrapper
:ajax-option="{
foo: true,
bar: false,
foobar: {
fool: 'ish'
}
}"></el-table-wrapper>
这两种写法可以同时存在,ajax-option-foo
这样的写法的值会覆盖 ajax-option
中指定的值。
多级对象
foobar.fool
支持Since 1.2.0
分页特有属性
增量分页特有属性
|名称|类型|默认值|描述|
|---|---|---|---|
|default-id|String/Number|''|默认的数据id,当未加载数据时,增量更新请求时使用此值|
|inc-size|String/Number|80|增量分页时每次向服务器请求的数据量|
|param-inc|String|lastId|增量加载数据时,增量参数名|
|inc-id|String|-|增量加载数据时,数据项的标识字段,未指定时,使用 idField
的值,用法与 idField
相同|
服务器分页特有属性
|名称|类型|默认值|描述|
|---|---|---|---|
|param-index|String|pageIndex|向服务器发送请求时,页码参数名|
|total-field|String|total|服务器分页时,返回数据中的数据总量字段名称|
|list-field|String|list|服务器分页时,返回数据中的数据列表字段名称|
|first-page-index|Number|0|向服务器发送请求时,第一页的页码值,默认为 0
|
本地分页特有属性
|名称|类型|默认值|描述| |---|---|---|---| |local-data|Array|-|本地分页时,设置本地数据。当此值变化时,本地数据会清空,然后再重新渲染|
方法
|名称|参数|返回值|描述|
|---|---|---|---|
|load|clear=true: Boolean|this|在使用服务器数据源时,调用此方法以从服务器加载数据|
|clear|-|this|清空数据并重置分页|
|cancel|-|this|取消尚未执行的ajax请求|
|info|-|Object(返回值见下方)|获取数据信息|
|append|data: Array/Object|this|向表格尾追加数据项|
|prepend|data: Array/Object|this|向表格头追加数据项|
|insert|data: Array/Object, index: Number|this|向表格指定位置追加数据项|
|update|data: Array/Object|this|从数据缓存中更新数据项|
|remove|data: Array/Object/String/Number|this|从数据缓存中移除数据项。参数可以是数据项,也可以是数据对应id-field
指定值|
|getRowId|row: Object, [idField]: string|this|根配置的 idField 读取数据项的 id|
|select|rows: Object/Array|this|选中指定的行。参数可以是数据项,也可以是数据对应id-field
指定值|
|selectAll|-|Array|全选当前页数据,仅在多选时生效,返回选中的数据项|
|deselect|rows: Object/Array|this|取消选中指定的行,参数可以是数据项,也可以是数据对应id-field
指定值|
|deselectAll|-|Array|取消全选当前页数据,仅在多选时生效,返回取消选中的数据项|
|toggle|rows: Object/Array|this|切换指定的行的选中状态,参数可以是数据项,也可以是数据对应id-field
指定值|
|toggleAll|-|this|切换当前页的选中状态,仅在多选时生效|
|getSelection|-|Array/Object|获取选中的行,单选时返回选中的行对象,多选时返回行集合|
|clearSelection|-|this|清除所有选中|
|clearSort|-|this|ElTable
的 clearSort
方法|
|clearFilter|-|this|ElTable
的 clearFilter
方法|
|doLayout|-|this|ElTable
的 doLayout
方法|
|sort|-|this|ElTable
的 doLayout
方法|
|toggleRowExpansion|-|this|ElTable
的 toggleRowExpansion
方法|
info()
返回值:
const data = {
// 页码
pageIndex: Number,
// 总页数
pageCount: Number,
// 每页的数据量
pageSize: Number,
// 总数据量
dataSize: Number,
// 选中数量
selected: Number
}
remove/select/deselect
的参数说明:
- 数组 处理多行数据 参数:
[{}, {}]
- 对象 处理单行数据
{}
- 字符串/数字 处理由
id-field
指定的行的标识值对应的单行数据1/'913a0229-cd5e-45a4-a57a698f2432774f'
since 0.7.3
- 字符串/数字(数组) 处理由
id-field
指定的行的标识值对应的多行数据[1, 2, 3]/['913a0229-cd5e-45a4-a57a698f2432774f', ...]
since 0.7.3
数据类型可以混用,参数:[{}, 3, '913a0229-cd5e-45a4-a57a698f2432774f', ...]
事件
|名称|参数|描述| |---|---|---| |ajax-error|{data, message, response}|加载ajax数据失败的事件| |load|{data}|异步加载数据成功,并且渲染完成后触发;每次数据加载都会触发此事件| |data-size-change|size: Number|表格数据量变化| |page-size-change|size: Number|表格每页显示的数据量变化| |page-index-change|index: Number|表格的页码变化| |select|selected: Object, prevSelected: Object|在单选时,行被点击后触发| |selection-change|{selection: Array, add: Array, remove: Array, allSelected: Boolean}|详见 selection-change| |cell-mouse-enter|-|ElTable 事件| |cell-mouse-leave|-|ElTable 事件| |cell-click|-|ElTable 事件| |cell-dblclick|-|ElTable 事件| |row-click|-|ElTable 事件| |row-contextmenu|-|ElTable 事件| |row-dblclick|-|ElTable 事件| |header-click|-|ElTable 事件| |header-contextmenu|-|ElTable 事件| |sort-change|-|ElTable 事件| |filter-change|-|ElTable 事件| |header-dragend|-|ElTable 事件| |expand-change|-|ElTable 事件|
selection-change
此事件在启用了多选时(selection=multiple
),选中或取消选中行时触发。
参数说明:
e = {
selection: [],
add: [],
remove: [],
allSelected: []
}
selection
当前选中的行集合add
此次新选中的行集合remove
此次被移除选中的行集合allSelected
标记是否已经选中了所有当前缓存的数据,当没有数据项时,allSelected
始终为false
type=l
时,表示local-data
指定的所有数据type=i
时,表示已经加载的所有数据type=s
时,表示当前页的数据
插槽
|名称|数据|描述|
|---|---|---|
|header|{data}|可选的表格顶部插槽|
|default|{toggle, select, deselect}|ElTable
的列集合,用法与 ElTable
的默认插槽相同|
|empty|-|ElTable
的 empty
插槽|
|append|-|ElTable
的 append
插槽|
|pagerPrepend|{data}|分页插槽,默认放在分页左侧|
|pagerAppend|{data}|分页插槽,默认放在分页右侧|
|pagerSummary|{data}|自定义的分页信息统计|
|footer|{data}|分页左侧的文字|
|titleToolbar|{data}|表格标题栏插槽,覆盖在标题栏上方 since 0.8.0
|
toggle, select, deselect
均为方法,可以直接调用。
可以使用
#footer="{data}"
或slot-scope="{data}"
来引用数据
注:
header
, footer
有相同的作用域数据:
const data = {
// 页码
pageIndex: Number,
// 总页数
pageCount: Number,
// 每页的数据量
pageSize: Number,
// 总数据量
dataSize: Number,
// 当前页的数据量
viewSize: Number,
// 选中数量
selected: Number
}
pagerPrepend
, pagerSummary
, pagerAppend
三个插槽有相同的作用域数据:
const data = {
pageIndex: Number,
pageCount: Number,
pageSize: Number,
dataSize: Number,
selected: Number,
viewSize: Number,
position: String['top', 'bottom']
}