Vue3.5 + Element-Plus 二次封装 el-table、el-form、el-descriptions

超级组件 基于 Vue3.5 + Element-Plus 最新版二次封装了 el-tableel-formel-descriptions 等常用组件,核心理念是通过「配置项(JSON)」来驱动页面的生成,无需编写大量的标签。

超级组件有如下组件:

  • ProTable 超级表格:基于 el-table 封装
  • ProForm 超级表单:基于 el-form 封装
  • ProFormGroup 分组表单:基于 ProForm 封装
  • ProFormDialog 弹框表单:基于 ProFormProDialog 封装
  • ProFormDrawer 抽屉表单:基于 ProFormProDrawer 封装
  • ProFormSteps 步骤表单组件:基于 ProFormel-steps 封装
  • ProSearch 超级搜索:基于 ProForm 封装
  • ProPage 超级页面组件:基于 ProTableProSearch 封装,可快速构建一个增删改查表格页面
  • ProDescriptions 超级描述列表:基于 el-descriptions 封装
  • ProDialog 超级弹框:基于 el-dialog 封装,支持函数式打开 el-dialog
  • ProDrawer 超级抽屉:基于 el-drwaer 封装,支持函数式打开 el-drwaer

在线预览

超级组件并不是作为单独的 NPM 包安装,而是作为独立组件运行在 Teek Design Vue3 项目里,因此可以在项目链接可以查看简单的 Demo 和预览超级组件的代码。

大家可以将超级组件复制到任意 Vue3 + Element-Plus 的项目里使用。

Teek Design Vue3 的文档链接里,超级组件有更详细的 Demo 示例和配置项说明。

Git 仓库 (欢迎 Star ⭐⭐⭐)

Github:github.com/Kele-Bingta...

Gitee:gitee.com/kele-bingta...

诞生

超级组件最开始只有超级表格,而超级表格最初来源于掘金的一篇 Vue3.2 + Element-Plus 二次封装 el-table(Pro 版 🚀🚀),在评论区也可以看到我的评论(😊),后逐步完善,衍生了超级表单和超级搜索等组件。

当时超级组件仿照最初的超级表格,使用 tsx 编写,如今已经全部使用 setup 模板风格重构。

在重构的过程中,我参考了 plus-pro-components 的设计思路,添加了基于超级表单衍生的分组表单,弹框表单等组件。

使用示例

这里仅列举常用的几个超级组件,更多的超级组件用法请看上方的在线预览链接。

超级表格

超级组件分为 4 个模块:

  1. 表格数据操作区域
  2. 表格功能按钮区域
  3. 表格主体区域
  4. 表格分页区域

通过传入 columnsdata 即可快速构建一个表格:

效果:

超级表单

传入配置项 columns 即可构建一个表单:

效果:

超级页面

超级页面基于超级表格和超级搜索组成。超级页面的 columns 在超级表格的 columns 基础上额外添加了 search 配置项,其他用法与超级表格的 columns 保持一致。

效果:

超级描述列表

传入配置项 columns 即可构建一个描述列表:

效果:

超级描述列表内置超级表单,可以通过传入 editable 来开启编辑功能。

超级弹框

超级弹框并没有对 el-dialog 过渡封装,仅仅添加了支持切换全屏的按钮。

兼容 ElementPlus 组件所有功能

超级组件的设计思路是:在完全不影响 ElementPlus 组件的所有属性、事件、插槽前提下进行拓展,你可以通过 columns 传入 ElementPlus 组件自带的任意功能。

相关推荐
m0_471199636 分钟前
【小程序】订单数据缓存 以及针对海量库存数据的 懒加载+数据分片 的具体实现方式
前端·vue.js·小程序
编程大师哥8 分钟前
Java web
java·开发语言·前端
A小码哥9 分钟前
Vibe Coding 提示词优化的四个实战策略
前端
Murrays9 分钟前
【React】01 初识 React
前端·javascript·react.js
大喜xi13 分钟前
ReactNative 使用百分比宽度时,aspectRatio 在某些情况下无法正确推断出高度,导致图片高度为 0,从而无法显示
前端
helloCat13 分钟前
你的前端代码应该怎么写
前端·javascript·架构
电商API_1800790524713 分钟前
大麦网API实战指南:关键字搜索与详情数据获取全解析
java·大数据·前端·人工智能·spring·网络爬虫
康一夏15 分钟前
CSS盒模型(Box Model) 原理
前端·css
web前端12315 分钟前
React Hooks 介绍与实践要点
前端·react.js
我是小疯子6616 分钟前
JavaScriptWebAPI核心操作全解析
前端