npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@wangankeji/eltable-wrapper

v1.4.10

Published

ElementUI ElTable和ElPagination 包装组件

Downloads

15

Readme

ElTableWrapper

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

注: 后将此组件 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|

多层的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对象。当 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']
}