element-ui 封装 表格

一、封装表格组件

javascript 复制代码
<template>
  <el-table :data="list" :default-sort="{ prop: 'date' }" style="width: 100%">
    <template v-for="item in tableColumn">
      <el-table-column
        v-if="item.filters"
        :prop="item.prop"
        :label="item.label"
        :sortable="item.sortable"
        :filters="item.filters"
        :filter-method="filterHandler(item.filterMethod)"
      />
      <el-table-column
        v-if="!item.filters"
        :prop="item.prop"
        :label="item.label"
        :sortable="item.sortable"
      />
    </template>
  </el-table>
</template>

<script scoped>
export default {
  data() {
    return {
      list: [],
      tableColumn: [],
    };
  },
  props: {
    data: {
      type: Array,
      default: [],
    },
    column: {
      type: Array,
      default: [],
    },
  },
  watch: {
    data: {
      immediate: true,
      deep: true,
      handler(val) {
        if (val.length) {
          this.list = JSON.parse(JSON.stringify(val));
        }
      },
    },
    column: {
      immediate: true,
      deep: true,
      handler(val) {
        if (val.length) {
          this.tableColumn = JSON.parse(JSON.stringify(val));
        }
      },
    },
  },
  methods: {
    // 如果没传,那么默认等值判断
    filterHandler(filterMethod) {
      if (filterMethod) {
        return item.filterMethod;
      } else {
        return (value, row, column) => {
          const property = column["property"];
          return row[property] === value;
        };
      }
    },
  },
};
</script>

二、使用方法

javascript 复制代码
<template>
  <div id="app"><Tabel :data="data" :column="column" /></div>
</template>

<script>
import Tabel from "@/components/Tabel.vue";
export default {
  components: { Tabel },
  data() {
    return {
      column: [
        {
          label: "日期",
          prop: "date",
          sortable: true,
        },
        {
          label: "姓名",
          prop: "name",
          filters: [{ text: "王小龙", value: "王小龙" }],
        },
        {
          label: "地址",
          prop: "address",
        },
      ],
      data: [
        {
          date: "2016-05-02",
          name: "王小猪",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小龙",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小海",
          address: "上海市普陀区金沙江路 1516 弄",
        },
      ],
    };
  },
};
</script>
相关推荐
詩句☾⋆᭄南笙17 小时前
HTML列表、表格和表单
服务器·前端·html·表格·列表·表单
硅谷工具人2 天前
基于element-plus封装table组件
elementui·el-table封装
咚咚咚小柒2 天前
【前端】用el-popover做通用悬停气泡(可设置弹框宽度)
前端·javascript·vue.js·elementui·html·scss
Stringzhua2 天前
ElementUi【饿了么ui】
前端·ui·elementui
尔嵘2 天前
vue2+elementUi实现自定义表格框选复制粘贴
前端·javascript·elementui
星光一影2 天前
HIS系统天花板,十大核心模块,门诊/住院/医保全流程打通,医院数字化转型首选
java·spring boot·后端·sql·elementui·html·scss
博客zhu虎康3 天前
Element中 el-tree 如何隐藏 Tree 组件中的父节点 Checkbox
javascript·vue.js·elementui
我总是词不达意4 天前
vue3 + el-upload组件集成阿里云视频点播从本地上传至点播存储
前端·vue.js·阿里云·elementui
通往曙光的路上4 天前
day9_elementPlus2
javascript·vue.js·elementui
Queen_sy6 天前
vue3 el-date-picker 日期选择器校验规则-选择日期范围不能超过七天
javascript·vue.js·elementui