XYGo Admin ArtTable 表格组件:一行代码搞定加载、刷新与分页

XYGo Admin ArtTable 表格组件:一行代码搞定加载、刷新与分页

做后台管理系统的同学都懂------表格是日常开发里出现频率最高的组件,没有之一。从数据列表到操作日志、从用户管理到订单查询,几乎每个页面都在跟表格打交道。

用原生 Element Plus 写表格倒也不难,但每次都要手写 loading、空状态、分页、刷新按钮这些"标配",琐碎又重复。今天聊聊 XYGo Admin 里内置的 ArtTable 表格组件,看看它是怎么把这几件事收拢到一起的。

ArtTable:带加载状态的表格封装

ArtTable 本质上是对 Element Plus ElTable 的一层轻封装,最明显的增强就是把 loading 状态内置了进去:

html 复制代码
<template>
  <ArtTable :loading="loading" :data="tableData">
    <ElTableColumn prop="title" label="标题" min-width="200" show-overflow-tooltip />
    <ElTableColumn prop="status" label="状态" width="80" align="center">
      <template #default="{ row }">
        <ElTag :type="row.status === 1 ? 'success' : 'danger'" size="small">
          {{ row.status === 1 ? '正常' : '禁用' }}
        </ElTag>
      </template>
    </ElTableColumn>
    <ElTableColumn label="操作" width="150" fixed="right">
      <template #default="{ row }">
        <ElButton link type="primary" size="small" @click="handleEdit(row)">编辑</ElButton>
        <ElButton link type="danger" size="small" @click="handleDelete(row.id)">删除</ElButton>
      </template>
    </ElTableColumn>
  </ArtTable>
</template>

用法和 ElTable 几乎一模一样,Props 也只多了 dataloading 两个。传个布尔值就能控制骨架屏,不用额外写 v-loading 指令。列定义还是用 ElTableColumn,所有 Element Plus 原生属性------sortablefixedshow-overflow-tooltip------照用不误。

ArtTableHeader:工具栏一步到位

有了表格主体,顶部操作栏也很常见:左边放「新增」「导出」按钮,右边放「刷新」图标。ArtTableHeader 把这个模式固化了:

html 复制代码
<template>
  <ArtTableHeader :loading="loading" @refresh="loadData">
    <template #left>
      <ElButton type="primary" @click="handleAdd">新增</ElButton>
      <ElButton @click="handleExport">导出</ElButton>
    </template>
  </ArtTableHeader>
</template>

就两个插槽------#left#right,外加一个 @refresh 事件。loading 传进去后刷新图标会自动旋转,不需要自己写状态切换逻辑。刷新事件触发后,你在回调里重新调接口 loadData() 就行。

完整组合:表头 → 表格 → 分页

把 ArtTableHeader、ArtTable、ElPagination 串起来,一个标准的列表页就出来了:

html 复制代码
<template>
  <ElCard shadow="never">
    <!-- 工具栏 -->
    <ArtTableHeader :loading="loading" @refresh="loadData">
      <template #left>
        <ElButton type="primary" v-auth="'add'">新增</ElButton>
      </template>
    </ArtTableHeader>

    <!-- 数据表格 -->
    <ArtTable :loading="loading" :data="tableData">
      <ElTableColumn prop="title" label="标题" min-width="200" />
      <ElTableColumn prop="status" label="状态" width="100" align="center" />
      <ElTableColumn label="操作" width="150" fixed="right" />
    </ArtTable>

    <!-- 分页 -->
    <div class="art-pagination">
      <ElPagination
        v-model:current-page="page"
        v-model:page-size="pageSize"
        :total="total"
        layout="total, sizes, prev, pager, next, jumper"
        @size-change="loadData"
        @current-change="loadData"
      />
    </div>
  </ElCard>
</template>

三件套组合下来,代码量不多但结构清晰。卡片容器统一视觉、工具栏负责操作入口、表格承载数据、分页控制数据量------这个布局就是 XYGo Admin 里大部分列表页的标配。

为什么选这套方案

后台管理里表格场景大同小异,把 loading 状态、刷新、分页这三件事收敛到组件层,好处很直接:

  • 少写模板代码 :不用每个页面都写一遍 v-loading@refresh、分页逻辑
  • 一致的用户体验:所有页面的加载动画、刷新交互、分页布局都是统一的
  • 保留原生灵活性:ElTableColumn 该咋写还咋写,没有学新 API 的成本

XYGo Admin 作为基于 GoFrame + Vue3 的敏捷后台开发框架,在组件封装上做了不少这种"顺手"的设计------不做大而全的抽象,只在最频繁的重复点上做收敛。ArtTable 就是一个很典型的例子。

更多内置组件可以参考官网文档:XYGo Admin 开发文档

相关推荐
一份执念3 分钟前
uni-app项目 (vue+vite + uni-UI)中引入umd格式JS文件,微信小程序中导入报错处理方案
前端·uni-app·echarts
ClouGence13 分钟前
2026 年自动化测试工具选型指南:8 款主流工具对比
前端·测试
lichenyang4531 小时前
为什么需要双线程通信、JavaScriptProxy 和 runJavaScript 分别干什么
前端
以和为贵1 小时前
前端也能搞懂 RAG:用 JS 手写一条最小检索增强链路
前端·人工智能·面试
风止何安啊1 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
牧艺1 小时前
用 Next.js + React Three Fiber 打造 3D 快递仓储可视化
前端·three.js
锋行天下2 小时前
如何用Vite实现Vue组件的按需打包和远程加载
前端·vue.js·前端框架
光影少年2 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
禅思院5 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮5 小时前
深入理解Loop Engineering
前端·后端