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 开发文档

相关推荐
之歆6 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6
lichenyang4537 小时前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端
IT_陈寒7 小时前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端
kyriewen7 小时前
AI生成代码快如闪电,但我修了三个小时——它到底帮了谁?
前端·javascript·ai编程
ayqy贾杰8 小时前
基层管理的三板斧,在AI时代行不通了
前端·后端·团队管理
Apifox8 小时前
Apifox 5 月更新|Postman 导入优化、Runner 支持非 root 运行、请求代码自动带鉴权
前端·后端·安全
miaowmiaow8 小时前
PSD2Code 近期更新与深度解析:从设计稿到生产级代码的完整技术栈
前端·人工智能·ai编程
Hilaku9 小时前
多标签页并发请求导致 Token 刷新失败?只有 15行代码就能解决 !
前端·javascript·程序员
Nile9 小时前
解密Palantir系列一:4. Ontology 不是哲学
开发语言·前端·javascript
因_崔斯汀9 小时前
ECharts 区域地图可视化实战:以山东地图为例
前端