当前位置:首页 > VUE

vue table组件实现

2026-03-08 06:44:35VUE

Vue Table 组件实现方法

基础表格实现

使用el-table组件快速构建表格,需绑定数据源并定义列:

<template>
  <el-table :data="tableData" style="width: 100%">
    <el-table-column prop="date" label="日期" width="180"></el-table-column>
    <el-table-column prop="name" label="姓名" width="180"></el-table-column>
    <el-table-column prop="address" label="地址"></el-table-column>
  </el-table>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        { date: '2023-01-01', name: '张三', address: '北京市' },
        { date: '2023-01-02', name: '李四', address: '上海市' }
      ]
    }
  }
}
</script>

动态列渲染

通过v-for动态生成表格列:

<el-table :data="tableData">
  <el-table-column 
    v-for="col in columns"
    :key="col.prop"
    :prop="col.prop"
    :label="col.label">
  </el-table-column>
</el-table>

自定义列模板

使用插槽实现复杂单元格内容:

<el-table-column label="操作">
  <template #default="scope">
    <el-button @click="handleEdit(scope.row)">编辑</el-button>
    <el-button @click="handleDelete(scope.row)">删除</el-button>
  </template>
</el-table-column>

表格排序与筛选

添加sortablefilters属性实现功能:

<el-table-column
  prop="date"
  label="日期"
  sortable
  :filters="[
    { text: '北京', value: '北京市' },
    { text: '上海', value: '上海市' }
  ]"
  :filter-method="filterHandler">
</el-table-column>

分页功能实现

结合el-pagination组件:

<el-pagination
  @size-change="handleSizeChange"
  @current-change="handleCurrentChange"
  :current-page="currentPage"
  :page-sizes="[10, 20, 30]"
  :page-size="pageSize"
  layout="total, sizes, prev, pager, next, jumper"
  :total="total">
</el-pagination>

性能优化建议

大数据量时启用虚拟滚动:

<el-table
  :data="tableData"
  height="400"
  v-loading="loading"
  row-key="id">
</el-table>

自定义样式

通过CSS覆盖默认样式:

vue table组件实现

.el-table .warning-row {
  background-color: #fff8e6;
}
.el-table .success-row {
  background-color: #f0f9eb;
}

标签: 组件vue
分享给朋友:

相关文章

vue实现选择季度

vue实现选择季度

Vue 实现选择季度的几种方法 使用下拉选择框(Select) 在 Vue 中可以通过 v-model 绑定一个下拉选择框来实现季度选择。数据可以预先定义为一个包含季度选项的数组。 <…

vue实现下拉刷新组件

vue实现下拉刷新组件

实现下拉刷新组件的核心思路 下拉刷新功能通常通过监听触摸事件、滚动位置和动画效果实现。Vue中可以利用自定义指令或封装组件完成,以下为两种常见实现方式。 基于自定义指令的实现 创建指令监听触摸事件,…

vue实现轮询

vue实现轮询

实现轮询的基本方法 在Vue中实现轮询可以通过setInterval或setTimeout配合递归调用完成。轮询通常用于定期向服务器请求数据更新。 使用setInterval的简单示例: data…

vue实现功能

vue实现功能

Vue 功能实现方法 Vue.js 是一个渐进式 JavaScript 框架,用于构建用户界面。以下是实现常见功能的几种方法: 数据绑定与响应式更新 在 Vue 中,数据绑定通过 v-model…

vue实现过程

vue实现过程

Vue 的实现过程 Vue 的实现过程可以分为多个核心模块,包括响应式系统、虚拟 DOM、模板编译等。以下是 Vue 的主要实现过程分析。 响应式系统 Vue 的响应式系统基于 Object.def…

vue slot实现

vue slot实现

vue slot 的实现方法 在 Vue 中,slot 是一种内容分发机制,允许父组件向子组件传递模板内容。以下是几种常见的 slot 实现方式: 默认 slot 默认 slot 是最基础的 slo…