# eltable-wrapper
**Repository Path**: wangankeji-fe/eltable-wrapper
## Basic Information
- **Project Name**: eltable-wrapper
- **Description**: 对 ElementUI 的 ElTable 和 ElPagination 的深度封装
- **Primary Language**: JavaScript
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 2
- **Forks**: 0
- **Created**: 2020-03-06
- **Last Updated**: 2025-01-21
## Categories & Tags
**Categories**: webui
**Tags**: None
## README
# ElTableWrapper
此组件封装了 `element-ui` 中的 `ElTable` 和 `ElPagination` 组件,以提供表格与分页一体化的展示效果。
> 注: 后将此组件 `ElTableWrapper` 统称为 `组件`
组件支持多种分页方式,[点此查看](./PAGINATION.md)
组件支持单元格编辑,[点此查看](./EDITOR.md)
> 原 `@hyjiacan/eltable-wrapper`
## 安装
```bash
npm install @wangankeji/eltable-wrapper
```
或
```bash
yarn add @wangankeji/eltable-wrapper
```
## 快速上手
*main.js*
```javascript
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)
```
```vue
```
## 属性
可以通过以下方式指定组件属性的默认值:
```javascript
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`(服务器分页),[去看看分页方式](PAGINATION.md)|
|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支持的属性](OPTIONS.md#ElTable支持的属性)
- `ElTable` 的原生事件支持见 [ElTable支持的事件](OPTIONS.md#ElTable支持的事件)
- `ElPagination` 的原生属性支持见 [ElPagination支持的属性](OPTIONS.md#ElPagination支持的属性)
> 多层的`id-field`使用数组而不是字符串,是为了便于处理某些字段中包含特殊字符(甚至是`.`符号)的情形
`id-field` 为函数的情形:
某些情况下,数据的主键并不只是一个字段,而是多个字段组合形成。此时使用函数能够快速处理:
```js
// 接收的参数为行数据对象
function idFieldGetter(row) {
// 返回值会作为数据的标识
return `${row.field1}_${row.field2}
}
```
`check-field` 示例:
```vue
{{row.isSelected}}
```
> `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](https://github.com/flitbit/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 函数,其格式如下:
```javascript
ajax({
option: {...}
})
```
上面代码中 `option` 就是 `ajax-option` 的值。
但有时候我们仅仅需要设置其中的一个或几个属性, 此时再写一个对象就显示繁琐了。于是,就支持了以下的简写:
```vue
```
以上写法等价于
```vue
```
这两种写法可以同时存在,`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()` 返回值:
```javascript
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](#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`),选中或取消选中行时触发。
参数说明:
```js
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` 有相同的作用域数据:
```javascript
const data = {
// 页码
pageIndex: Number,
// 总页数
pageCount: Number,
// 每页的数据量
pageSize: Number,
// 总数据量
dataSize: Number,
// 当前页的数据量
viewSize: Number,
// 选中数量
selected: Number
}
```
`pagerPrepend`, `pagerSummary`, `pagerAppend` 三个插槽有相同的作用域数据:
```javascript
const data = {
pageIndex: Number,
pageCount: Number,
pageSize: Number,
dataSize: Number,
selected: Number,
viewSize: Number,
position: String['top', 'bottom']
}
```