封装一个简单的table组件

子组件

javascript 复制代码
<template>  
  <el-table :data="tableData" :headers="tableHeaders" style="width: 100%">  
    <el-table-column v-for="header in tableHeaders" :key="header.prop" :label="header.label" :prop="header.prop"></el-table-column>  
  </el-table>  
</template>  
  
<script>  
export default {  
  name: 'tableComponent',  
  props: {  
    tableData: {  
      type: Array,  
      required: true  
    },  
    tableHeaders: {  
      type: Array,  
      required: true  
    }  
  }  
}  
</script>

在这个示例中,我们添加了一个名为tableHeaders的属性,该属性是一个包含表头配置的数组。每个表头配置对象包含一个label和一个prop属性,用于显示列标题和与数据的对应关系。在模板部分,我们使用v-for指令循环渲染每个表头,并将表头配置对象的属性绑定到el-table-column组件中。通过这种方式,您可以根据需要动态更改表头。

父组件

javascript 复制代码
<template>  
  <div>  
    <tableComponent :tableData="tableData"  :tableHeaders="tableHeaders"/>  
  </div>  
</template>  
  
<script>  
import tableComponent from './tableComponent.vue';  
  
export default {  
  name: 'ParentComponent',  
  components: {  
    tableComponent  
  },  
  data() {  
    return {  
      tableData: [  
        { id: 1, name: '张三', age: 25, address: '北京市朝阳区' },  
        { id: 2, name: '李四', age: 30, address: '上海市浦东新区' },  
        { id: 3, name: '王五', age: 28, address: '广州市天河区' }  
      ],  
      tableHeaders: [  
        { label: '姓名', prop: 'name' },  
        { label: '年龄', prop: 'age' },  
        { label: '地址', prop: 'address' }  
      ]  
    };  
  }  
}  
</script>

在这个示例中,我们首先引入了tableComponent子组件。在父组件的data中,我们定义了tableData和tableHeaders两个属性,分别用于存储表格的数据和表头配置。您可以通过修改tableData和tableHeaders来更改表格的内容和外观。通过这种方式,您可以轻松地在父组件中使用可定制化的表格子组件。

相关推荐
thatway19897 小时前
闲聊-关于AI终结者的警醒
前端
努力的小郑7 小时前
突发!Claude Code 51万行源码全网裸奔:一场史诗级“开源”事故,国内大厂笑麻了
前端·后端·ai编程
七度黑光7 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
HashTang7 小时前
Claude Code 源码中 REPL.tsx 深度解析:一个 5005 行 React 组件的架构启示
前端·后端·ai编程
wendycwb8 小时前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript
终端鹿8 小时前
Vue3 模板引用 (ref):操作 DOM 与子组件实例 从入门到精通
前端·javascript·vue.js
千寻girling8 小时前
不知道 Java 全栈 + AI 编程有没有搞头 ?
前端·人工智能·后端
小码哥_常9 小时前
Android开发:精准捕获应用的前后台行踪
前端
蜡台9 小时前
Vue 打包优化
前端·javascript·vue.js·vite·vue-cli
木斯佳9 小时前
前端八股文面经大全:快手前端一面 (2026-03-29)·面经深度解析
前端·宏任务·原型链·闭包