This package has been deprecated

Author message:

Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.

@hyjiacan/eltable-wrapper

1.4.1 • Public • Published

ElTableWrapper

此组件封装了 element-ui 中的 ElTableElPagination 组件,以提供表格与分页一体化的展示效果。

注: 后将此组件 ElTableWrapper 统称为 组件

组件支持多种分页方式,点此查看

组件支持单元格编辑,点此查看

安装

npm install @hyjiacan/eltable-wrapper

yarn add @hyjiacan/eltable-wrapper

快速上手

main.js

import Vue from 'vue'
import ElTableWrapper from '@hyjiacan/ElTableWrapper'
import '@hyjiacan/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 '@hyjiacan/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

多层的id-field使用数组而不是字符串,是为了便于处理某些字段中包含特殊字符(甚至是.符号)的情形

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对象。当 typeis 时是必须的
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以阻止继续执行,返回trueundefined使用原参数继续执行
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 ElTableclearSort 方法
clearFilter - this ElTableclearFilter 方法
doLayout - this ElTabledoLayout 方法
sort - this ElTabledoLayout 方法
toggleRowExpansion - this ElTabletoggleRowExpansion 方法

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 - ElTableempty 插槽
append - ElTableappend 插槽
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']
}

Package Sidebar

Install

npm i @hyjiacan/eltable-wrapper

Weekly Downloads

1

Version

1.4.1

License

MIT

Unpacked Size

834 kB

Total Files

24

Last publish

Collaborators

  • hyjiacan