封装Element-table

后台管理的表格封装,高效搬砖!

        直接可以拿来用,或者是自己可以改改,绝对适用大部分后台的表格,再次做个记录,也方便自己以后方便随取随用... , el-pagination其中有一个分切切换,就是简单封装一下引入就行了

        HTML部分        

<template>
  <div class="base-table" v-loading="$attrs.loading">
    <el-table
      ref="baseTable"
      :data="$attrs.data"
      :stripe="$attrs.stripe !== false"
      style="width: 100%"
      tooltip-effect="light"
      v-bind="$attrs"
      v-on="$listeners"
      :row-key="rowKey"
    >
      <el-table-column
        v-if="showSelection || $attrs.selection"
        label="选择"
        type="selection"
        width="55"
        :reserve-selection="true"
        :selectable="selectable"
      />
      <el-table-column
        v-if="showIndex"
        :fixed="indexFixed"
        :index="indexMethod"
        :label="indexLabel"
        :type="type"
        :width="indexWidth"
      />
      <el-table-column
        v-for="(item, idx) in tableConf"
        :key="idx"
        :fixed="item.fixed || false"
        :label="item.label"
        :width="item.width || ''"
        :min-width="item.minWidth || ''"
        :max-width="item.maxWidth || ''"
        :align="item.align"
        :type="item.type"
        :show-overflow-tooltip="
          typeof item.showOverflowTooltip === 'undefined'
            ? true
            : item.showOverflowTooltip
        "
      >
        <template slot-scope="scope">
          <span v-if="item.dic">{{
            item.dic[scope.row[item.prop]] || "--"
          }}</span>
          <span v-else-if="item.rich" v-html="scope.row[item.prop]" />
          <span v-else-if="item.func">{{
            item.func(scope.row, item.prop)
          }}</span>
          <!-- 中间自定义列 -->
          <span v-else-if="item.selfDefine || item.custom">
            <slot
              name="column"
              :data="scope.row"
              :index="scope.$index"
              :prop="item.prop"
              :scope="scope"
            ></slot>
          </span>
          <span v-else-if="$slots[item.prop]">
            <slot
              :name="item.prop"
              :data="scope.row"
              :index="scope.$index"
              :scope="scope"
            />
          </span>
          <span v-else-if="$scopedSlots[item.prop]">
            <slot
              :name="item.prop"
              :data="scope.row"
              :index="scope.$index"
              :scope="scope"
            />
          </span>
          <span v-else-if="item.type === 'index'">{{
            indexMethod(scope.$index)
          }}</span>
          <span v-else>{{ formatValue(scope.row, item.prop) }}</span>
        </template>
      </el-table-column>
      <!-- 自定义其他列 -->
      <slot></slot>
      <!-- 自定义操作列-->
      <el-table-column
        v-if="operate"
        :fixed="operateFixed"
        :label="operateLabel"
        :width="operateWidth"
        :align="operateAlign"
      >
        <template slot-scope="scope">
          <slot
            :data="scope.row"
            :index="scope.$index"
            :scope="scope"
            name="edit"
          />
          <el-button
            v-if="useDelete"
            type="text"
            class="table-delete-btn-text"
            @click="onDelete(scope.row, scope.$index)"
            >删除</el-button
          >
        </template>
      </el-table-column>
    </el-table>
    <div v-if="page" :class="{ 'hidden-pagination': hiddenPagination }">
      <ty-page
        v-if="usePage"
        :hide-on-single-page="total < 15"
        :current-page="+queryInfo.page"
        :page-size="+queryInfo.size"
        :total="+total"
        @current-change="val => $emit('page-change', val)"
        @size-change="val => $emit('size-change', val)"
      />
      <el-pagination
        v-else
        :current-page="+queryInfo.page"
        :hide-on-single-page="true"
        :page-size="+queryInfo.size"
        :total="+total"
        layout="total, prev, pager, next"
        @current-change="val => $emit('page-change', val)"
      />
    </div>
  </div>
</template>

JavaScript部分

export default {
  name: "BaseTable",
  components: { TyPage },
  props: {
    // 表格配置项,非必填
    hiddenPagination: {
      type: Boolean,
      default: false
    },
    tableConf: Array,
    type: {
      type: String,
      default: "index"
    },
    showSelection: {
      type: Boolean,
      default: false
    },
    rowKey: {
      type: String,
      default: "id"
    },
    selectable: {
      type: Function,
      default: function() {
        return true;
      }
    },
    // 序号相关
    showIndex: {
      type: Boolean,
      default: true
    },
    indexFixed: {
      type: [Boolean, String],
      default: true
    },
    indexLabel: {
      type: String,
      default: "序号"
    },
    indexWidth: {
      type: [String, Number],
      default: "80"
    },
    // 是否提供删除功能,删除功能将解决分页查询问题,需要与分页共存
    useDelete: {
      type: Boolean,
      default: false
    },
    deleteTitle: {
      type: String,
      default: "操作提示"
    },
    deleteTips: {
      type: String,
      default: "确定执行删除操作?"
    },
    // 分页相关
    // 是否使用分页
    page: {
      type: Boolean,
      default: true
    },
    total: {
      type: Number
    },
    // 查询信息,分页必传,尤其是分页参数
    queryInfo: {
      type: Object,
      default: () => ({})
    },
    // 自定义操作列
    operateAlign: {
      type: String,
      default: "left"
    },
    operateLabel: {
      type: String,
      default: "操作"
    },
    // 操作列是否固定,可选值(true、false、left、right)
    operateFixed: {
      type: [Boolean, String],
      default: "right"
    },
    operateWidth: {
      type: String,
      default: "150"
    },
    // 操作权限
    operate: {
      type: Boolean,
      default: false
    }
  },
  computed: {
    usePage() {
      const sizeChangeFn =
        this.$listeners["size-change"] || this.$listeners.sizeChange;
      return !!sizeChangeFn;
    }
  },
  methods: {
    formatValue(row, prop) {
      if (prop === "") return prop ?? "--";
      if (prop?.includes(".")) {
        const args = prop.split("."),
          len = args.length - 1;
        let value = "",
          x = 0;
        try {
          while (x <= len) {
            if (row[args[x]]) {
              value = row[args[x]];
              value = value[args[++x]];
            } else {
              x++;
            }
          }
        } catch (e) {
          console.log(e);
          value = "";
        }
        return value ?? "--";
      }
      return row?.[prop] ?? "--";
    },
    getBaseTable() {
      return this.$refs.baseTable;
    },
    indexMethod(idx) {
      if (this.page && this.queryInfo.page && this.queryInfo.size) {
        return idx + 1 + (this.queryInfo.page - 1) * this.queryInfo.size;
      } else {
        return idx + 1;
      }
    },
    async onDelete(row, index) {
      try {
        await operateDialog({
          title: this.deleteTitle,
          message: this.deleteTips
        });
        this.$emit("delete", row, index);
      } catch (e) {
        console.log("onDelete -> e", e);
        if (e === "cancel") {
          this.$emit("delete-cancel", row, index);
        }
      }
    }
  }
};

分页器封装

<template>
  <el-pagination
    layout="total, prev, pager, next, sizes"
    :page-sizes="pageSizes"
    v-bind="$attrs"
    v-on="$listeners"
  />
</template>
<script>

export default {
  name: "TyPage",
  computed: {
    pageSizes() {
      return pageSizes;
    }
  }
};
</script>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Element-UI 是一套基于 Vue.js 2.0 的 UI 组件库,提供了丰富的组件和模板,方便我们快速开发页面。其中,Table 组件是常用的数据展示组件之一,我们可以通过封装一个 TableList 组件来简化 Table 的使用。 以下是一个简单的 TableList 封装示例: ```vue <template> <div> <el-table :data="tableData" :height="height" :max-height="maxHeight" :stripe="stripe" :border="border" :default-sort="defaultSort" :show-header="showHeader" :highlight-current-row="highlightCurrentRow"> <el-table-column v-for="(column, index) in columns" :key="index" :label="column.label" :prop="column.prop" :width="column.width" :min-width="column.minWidth" :fixed="column.fixed" :resizable="column.resizable" :formatter="column.formatter" :show-overflow-tooltip="column.showOverflowTooltip"></el-table-column> </el-table> </div> </template> <script> export default { name: "TableList", props: { tableData: { type: Array, default: () => [] }, columns: { type: Array, default: () => [] }, height: { type: String, default: "" }, maxHeight: { type: String, default: "" }, stripe: { type: Boolean, default: true }, border: { type: Boolean, default: true }, defaultSort: { type: Object, default: () => {} }, showHeader: { type: Boolean, default: true }, highlightCurrentRow: { type: Boolean, default: true } } }; </script> ``` 在这个组件中,我们定义了以下 props: - `tableData`:表格数据,类型为 Array。 - `columns`:表格列的配置项,类型为 Array。每个配置项包含 `label`(列名)、`prop`(对应数据源的字段名)、`width`(列宽度)等属性。 - `height`:表格高度,类型为 String。 - `maxHeight`:表格最大高度,类型为 String。 - `stripe`:是否显示斑马纹,类型为 Boolean。 - `border`:是否显示边框,类型为 Boolean。 - `defaultSort`:默认排序规则,类型为 Object,包含 `prop`(排序字段名)和 `order`(排序方式)两个属性。 - `showHeader`:是否显示表头,类型为 Boolean。 - `highlightCurrentRow`:是否高亮当前行,类型为 Boolean。 通过封装这个 TableList 组件,我们可以在项目中更加方便地使用 Element-UI 的 Table 组件,同时也可以减少代码重复。 ### 回答2: element-ui是一款基于Vue.js的UI组件库,而tableList是element-ui中的一个组件封装tableList组件的主要作用是用于展示和管理数据表格。它提供了丰富的功能和选项,使得我们可以快速地构建出符合需求的数据表格界面。 首先,我们可以通过tableList组件来定义表格的列,包括列的名称、宽度、对齐方式等。可以根据实际需求设置不同的列,并且还可以对列进行排序、隐藏等操作。 其次,tableList组件还支持分页功能,可以根据数据的大小自动生成相应的分页器,方便用户浏览和查找数据。 另外,tableList还提供了搜索和筛选的功能,用户可以根据表格中的内容进行搜索和筛选操作,以方便快速找到想要的数据。 此外,tableList还支持多选、单选等操作,用户可以通过复选框或者单选按钮来选择需要的数据进行操作。 总的来说,tableList是element-ui中的一个封装组件,它简化了数据表格的开发和管理,提供了丰富的功能和选项,使得我们能够更加灵活和高效地展示和管理数据表格。 ### 回答3: element-ui封装中的tableList是对element-ui中的Table组件进行封装后的一个自定义组件。该组件可以方便地在项目中使用Table,减少重复代码的编写。 tableList的特点是具有高度的可定制性和扩展性。通过传入不同的参数和配置,可以实现不同的表格功能和样式。例如,可以通过指定columns来定义表格的列数和展示内容;通过指定data来传入数据源;通过设置pagination来实现分页等功能。 在tableList组件中,我们还可以通过插槽(slot)的方式来自定义表格的一些样式和功能。比如,可以使用slot="header"来自定义表头,使用slot-scope在插槽内部可以访问到每一行的数据。 除了基本的表格功能外,tableList还可以在数据源发生变化时进行自动刷新,通过设置@refresh事件来实现数据的实时更新。 总之,element-ui封装tableList组件可以帮助我们快速搭建出功能齐全、扩展性强的表格展示页面。它简化了我们对Table组件的使用,提高了开发效率,同时保留了element-ui原本的特性和优势。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

33搬砖记.

鼓励一下作者发布更多前端内容

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值