Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lq782655835/el-table-plus
基于el-table的配置化组件
https://github.com/lq782655835/el-table-plus
element-table element-ui schema
Last synced: about 2 months ago
JSON representation
基于el-table的配置化组件
- Host: GitHub
- URL: https://github.com/lq782655835/el-table-plus
- Owner: lq782655835
- Created: 2020-03-04T04:12:56.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-12T03:41:29.000Z (about 2 years ago)
- Last Synced: 2024-05-28T16:09:49.904Z (8 months ago)
- Topics: element-table, element-ui, schema
- Language: Vue
- Homepage: https://lq782655835.github.io/el-table-plus
- Size: 2.89 MB
- Stars: 15
- Watchers: 2
- Forks: 1
- Open Issues: 27
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
README
# el-table-plus ![](https://img.shields.io/badge/license-MIT-F44336.svg)
> 基于el-table的配置化组件
背景:使用element el-table时,总要书写过多的template模板代码,使得页面html代码过多。从应用层看element组件库,虽然api设计的十分灵活,但使用起来十分繁琐。所以需要对el-table进行包装,简化相关配置。
应用层api设计比较好的,推荐[antd-design-vue table](https://antdv.com/components/table-cn/),el-table-plus api设计就参考了antd-design-vue table组件,底层渲染依然沿用element-ui table组件。同时全属性/事件支持原element table组件,不会破坏原有的api(无侵入);同时支持slot/jsx/h函数三种方式自定义渲染列数据,实现自定义业务逻辑渲染;同时集成常用的pagination组件以及扩展api,帮助便捷处理常用业务。
## 在线案例
https://lq782655835.github.io/el-table-plus
## 特点
1. 简单的使用方式,只需要data和column两个属性即可支持
1. 全继承,element-ui全属性/事件继承
1. 高扩展,支持slot/jsx/h函数三种方式自定义渲染列数据
1. 更便捷,扩展scroll事件、pagination组件、fn快捷格式化## 安装和引入
安装
``` bash
yarn add @springleo/el-table-plus
```引入
该组件依赖element-ui的el-table组件,需要自行引入。
``` js
import ElementUI from "element-ui";
import "element-ui/lib/theme-chalk/index.css";
Vue.use(ElementUI);import ElTablePlus from '@springleo/el-table-plus'
Vue.use(ElTablePlus)
```## 基本使用
``` html
```
## API
### el-table-plus 属性
支持el-table上所有[原有属性](https://element.eleme.cn/#/zh-CN/component/table#table-attributes),同时扩展以下api。
参数 | 类型 | 默认值 | 说明
--- | --- | --- | ---
loading | Boolean | false | 动效loading
data | Array | [] | 列表数据
columns | Array | [] | column item配置列表,详细见[如下columns Attrs](#columns-属性)
pagination | Object | | 翻页器配置,默认未设置,不显示翻页器。相关api可查看[el-pagination](https://element.eleme.cn/#/zh-CN/component/pagination#attributes)
total | Number | 0 | 翻页器条数总数### el-table-plus 事件
支持el-table上所有[原有事件](https://element.eleme.cn/#/zh-CN/component/table#table-events),同时扩展以下api。
事件名称 | 说明 | Description
--- | --- | ---
scroll | table滚动条事件 | e
page-change | 翻页器改变事件 | { pageSize, currentPage }### columns 属性
支持el-table-column所有[原有属性](https://element.eleme.cn/#/zh-CN/component/table#table-column-attributes)、[Scoped Slot](https://element.eleme.cn/#/zh-CN/component/table#table-column-scoped-slot),同时扩展以下api:
Attr | Type | Default | Description
--- | --- | --- | ---
label | String | | 列名称
prop | String | | 列数据字段,支持多层对象嵌套,如user.email.prefix
hidden | Boolean | | 是否隐藏该列。建议是一个computed,使得可以响应式显示隐藏
customRender | Function | | 自定义列数据渲染。函数参数(value, row, column, $index, h),**支持jsx和h函数**
customTitle | Function | | 自定义列头部渲染。函数参数(column, $index, h),**支持jsx和h函数**
scopedSlots | Object | | **使用slot方式自定义渲染**,替换customRender/customTitle函数。比如:{ customRender: 'slotName1', customTitle: 'slotName2' }## Vue plugin series
| Plugin | Status | Description |
| :---------------- | :-- | :-- |
| [@springleo/el-dialog-helper](https://github.com/lq782655835/el-dialog-helper) | ![](https://img.shields.io/badge/license-MIT-F44336.svg) | Promisify dialogs in Vue! |
| [@springleo/el-table-plus](https://github.com/lq782655835/el-table-plus) | ![](https://img.shields.io/badge/license-MIT-F44336.svg) | 基于el-table的配置化组件|
| [@springleo/el-form-plus](https://github.com/lq782655835/el-form-plus) | ![](https://img.shields.io/badge/license-MIT-F44336.svg) | schema form base on element-ui form |
| [@springleo/virtual-scroll-table](https://github.com/lq782655835/virtual-scroll-table) | ![](https://img.shields.io/badge/license-MIT-F44336.svg) | 无限下拉虚拟滚动table组件 |## License
MIT