如何二次封装一个el-table组件并二次复用

news2024/11/25 15:46:30

*注:示例使用的是vue3和element+进行二次封装的

首先我们来看效果图(总共可以分为以下几个模块):

  1. 表格数据操作按钮区域
  2. 表格信息提示区域
  3. 表格主体内容展示区域
  4. 表格分页区域

表单搜索没有封装在这里是为了降低代码的耦合性(有兴趣的可以查看我之前写的搜索框封装如何封装一个后管的输入框按钮组件基础版(可多次复用)_小羊集事笨的博客-CSDN博客)

以下是代码:

<script setup>
import { computed, ref } from "vue"
const props = defineProps({
  // 表格按钮个数
  btnArray: {
    type: Array,
    default: () => []
  },
  // 是否显示右侧提示
  showTip: {
    type: Boolean,
    default: false
  },
  // 表格数据
  tableData: {
    type: Array,
    default: () => []
  },
  //数据的条数
  total: {
    type: Number,
    default: 0
  },
  // 头部字段
  fields: {
    type: Array,
    default: () => []
  },
  // 字典(状态值,例如:0开始,1进行中,2结束)
  dict: {
    type: Object,
    default: () => {}
  },
  // 是否可选
  tableSelect: {
    type: Boolean,
    default: false
  },
  // 是否显示序号
  tableIndex: {
    type: Boolean,
    default: false
  },
  // 是否需要加载层
  loading: {
    type: Boolean,
    default: false
  },
  page: Number,
  pageSize: Number
})

const operation = ref(null)
// 动态计算操作列宽度
const winth = computed(() => {
  const length = operation.value?.$el.children.length
  const btnsWidth = length * 15 + length * 50
  return btnsWidth
})
// 车位总数
const sum = ref(666)
//动态计算占比
const Proportion = computed(() =>  props.total / sum.value )
const emit = defineEmits(["btnHandle", "selectionChange", "sizeChange", "currentChange"])

// 切换条数
const sizeChange = (ev) => {
  emit("sizeChange", ev)
}
// 切换页数
const currentChange = (ev) => {
  emit("currentChange", ev)
}

// 获取按钮颜色
const getColor = (name) => {
  if (name == "批量删除") {
    return ""
  }
  return "primary"
}

// 点击头部按钮
const btnHandle = (name) => {
  emit("btnHandle", name)
}

// 点击选择框
const selectionChange = (ev) => {
  emit("selectionChange", ev)
}

// 字典,处理数字对应的映射字段
const filterDictType = (value, array, code = "value", name = "label") => {
  if (!value && value !== 0) {
    // 要把0摘出来,一般0都是正常的数据,所以不能只用  !value
    return ""
  }
  const findObj = array.find((item) => item[code] === value.toString() || item[code] === +value) // 字符型数值型都得匹配

  if (find) {
    return findObj[name]
  } else {
    // 没有匹配的就原样返回
    return value
  }
}
</script>

<template>
  <el-card>
    <!-- 头部按钮 -->
    <div class="table-header">
      <div class="header-button">
        <el-button v-for="item in btnArray" :key="item" :type="getColor(item)" @click="btnHandle(item)">{{
          item
        }}</el-button>
      </div>

      <el-alert
        v-if="showTip"
        :title="`本园区共计 ${sum} 个车位,月卡用户 ${total}人,车位占有率 ${Proportion}%`" 
        show-icon
        :closable="false"
      />
    </div>
    <!-- 表格 -->
    <el-table :data="tableData" v-loading="loading" style="width: 100%" @selection-change="selectionChange">
      <el-table-column v-if="tableSelect" type="selection" width="55" />
      <el-table-column v-if="tableIndex" label="序号" type="index" width="55" />
      <template v-for="(item, index) in fields" :key="index">
        <el-table-column
          show-overflow-tooltip
          :prop="item.prop"
          :label="item.label"
          :width="item.label.indexOf('时间') >= 0 ? 220 : ''"
          min-width="140"
        >
          <template v-slot="{ row }">
            <!-- 处理根据不同的值显示不同的内容 -->
            <div v-if="item.dictType">
              {{ tableData.length && filterDictType(row[item.prop], dict[item.dictType]) }}
            </div>
            <!-- 可点击td -->
            <el-link v-else-if="item.isHandle" @click="tdHandle(row.id, item.label, row)">{{ row[item.prop] }}</el-link>
            <!-- 可解析html -->
            <span v-else-if="item.isHtml" v-html="row[item.prop]" />
            <span v-else>{{ row[item.prop] }}</span>
          </template>
        </el-table-column>
      </template>
      <!-- 操作列 -->
      <el-table-column ref="operation" :width="winth + 'px'" fixed="right" label="操作">
        <template v-slot="{ row }">
          <slot :row="row" />
        </template>
      </el-table-column>
    </el-table>
    <!-- 分页 -->
    <el-row justify="end">
      <el-pagination
        layout="total, sizes, prev, pager, next, jumper"
        :page-sizes="[10, 20, 30, 40, 50]"
        :total="total"
        :page-size="pageSize"
        :currentPage="page"
        @size-change="sizeChange"
        @current-change="currentChange"
      />
    </el-row>
  </el-card>
</template>

<style lang="scss" scoped>
.table-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 20px;
  .el-alert--info.is-light {
    height: 40px;
    font-size: 14px;
    border: 1px solid #91d5ff;
    background-color: #e6f7ff;
    :deep(.el-alert__title) {
      color: #000000d9;
    }
  }
}

.el-alert {
  width: auto;
}

.el-pagination {
  margin: 16px 0;
}

:deep(.el-card__body) {
  padding-bottom: 0;
}

.el-card.is-always-shadow {
  box-shadow: none;
  border: none;
}
</style>

这段代码是一个Vue组件,它定义了一个可重用的表格组件,具有以下功能:

  1. <script setup>标签中,使用Vue 3的definePropsdefineEmits函数定义了组件的属性(props)和事件(emits)。

    • btnArray:表格按钮的数组,默认为空数组。
    • showTip:是否显示右侧提示,默认为false。
    • tableData:表格数据的数组,默认为空数组。
    • total:数据的条数,默认为0。
    • fields:头部字段的数组,默认为空数组。
    • dict:字典,用于处理数字对应的映射字段,默认为空对象。
    • tableSelect:是否可选,布尔值,默认为false。
    • tableIndex:是否显示序号,布尔值,默认为false。
    • loading:是否需要加载层,布尔值,默认为false。
    • page:当前页数,数字类型。
    • pageSize:每页显示的条数,数字类型。
  2. 使用ref函数创建了operationsum的引用,以及计算属性winthProportion

    • operation:操作列的引用。
    • sum:车位总数,默认为666。
    • winth:动态计算操作列的宽度。
    • Proportion:动态计算数据条数占总数的比例。
  3. 使用defineEmits函数定义了四个事件:btnHandleselectionChangesizeChangecurrentChange

  4. 定义了一些辅助函数:

    • sizeChange:切换条数的函数,当条数发生变化时触发sizeChange事件。
    • currentChange:切换页数的函数,当页数发生变化时触发currentChange事件。
    • getColor:根据按钮名称返回按钮颜色的函数。
    • btnHandle:点击头部按钮的函数,当按钮被点击时触发btnHandle事件。
    • selectionChange:点击选择框的函数,当选择框的状态发生变化时触发selectionChange事件。
    • filterDictType:根据字典处理数字对应的映射字段的函数。
  5. <template>标签中,使用Element UI的组件构建了一个表格和分页器的布局。

    • <el-card>:卡片容器。
    • <div class="table-header">:表格头部,包含按钮和提示信息。
    • <el-button>:头部按钮,根据btnArray中的按钮数组动态生成。
    • <el-alert>:右侧提示信息,显示车位总数、总人数和占有率。
    • <el-table>:表格组件,用于显示表格数据。
    • <el-table-column>:表格列组件,根据fields数组动态生成表格列。
    • <el-link>:可点击的表格单元格。
    • <span>:普通的表格单元格。
    • <slot>:插槽内容,用于显示操作列的自定义按钮或组件。
    • <el-pagination>:分页器组件,根据数据条数、当前页数和每页条数进行分页。

这个表格组件可以根据传入的属性和事件进行配置,生成一个带有按钮、提示信息、可选、序号、加载层、分页等功能的表格,并支持自定义操作列的按钮或组件。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/760496.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ChatGPT开发【一】:打造与ChatGPT默契互动的绝佳输入格式

点击加入->【OpenAI-API开发】技术交流群 文章目录 1. 导入openai库2.示例聊天API调用3.GPT-3.5-Turbo-0301的使用技巧系统消息Few-show prompt 4.计数Token数 Chatgpt由Openai最先进的型号 gpt-3.5-Turbo和 gpt-4提供支持。我们可以使用OpenAI API使用 GPT-3.5-Turbo或…

谈谈在Bitcask中用读写锁实现并发控制的性能表现

背景 最近被问了几次nutsdb事务是怎么实现的&#xff0c;也就是并发控制是怎么做的。我说&#xff0c;用一把大的读写锁&#xff0c;写事务拿到写锁&#xff0c;读事务拿读锁&#xff0c;这样子做的。提问者先是震惊&#xff0c;接着说是有一点鄙夷&#xff0c;我感觉大概心里…

【踩坑指南】Django+channels WebSocket配置

目前我搜到网上所有配置Djangochannels的教程/博客中&#xff0c;都没有提及这一点。希望能帮助你 踩的坑必须写在最前面&#xff1a; 根据文档的步骤去配置&#xff0c;每次到执行python manage.py 的时,使用的是默认的development server&#xff0c;而不是我们想要的Star…

解决:.prettierrc 配置完后,自动保存并没有格式化代码

如果你也碰到了同样的问题&#xff0c;请先确保&#xff1a; .prettierrc 文件已正确配置&#xff0c;例如我的&#xff1a; {"semi": false,"singleQuote": true,"arrowParens": "always","trailingComma": "all&qu…

卷积神经网络参数量和计算量的计算方法

本文总结了标准卷积、分组卷积和全连接层参数量和计算量的计算方法&#xff0c;如有错误&#xff0c;麻烦大家指正 一、标准卷积 假设输入特征的shape为[, , ]&#xff0c;卷积核的shape为[, , , ]&#xff0c;输出特征的shape为[, , ]&#xff0c;则&#xff0c; 标准卷积运…

C++特殊类设计及类型转换

目录 一、特殊类的设计 1.不能被拷贝的类 2.只能在堆区构建对象的类 3.只能在栈区构建对象的类 4.不能被继承的类 二、单例模式 1.饿汉模式 2.懒汉模式 3.线程安全 4.单例的释放 三、C类型转换 1.C语言的类型转换 2.static_cast 3.reinterpret_cast 4.const_cas…

Python补充笔记1-字符串

目录 1.字符串的驻留机制​编辑 2.字符串查找 2.1字符串查询操作方法 3.字符串大小写转换 3.1字符串的大小写转换方法 4.字符串内容对齐 4.1字符串内容对齐操作方法 5.字符串的劈分 5.1字符串劈分操作的方法​编辑 6.字符串判断 6.1判断字符串操作的方法​编辑 6.2字符串替换和…

虚拟化技术及实时虚拟化概述

版权声明&#xff1a;本文为本文为博主原创文章&#xff0c;未经本人同意&#xff0c;禁止转载。如有问题&#xff0c;欢迎指正。博客地址&#xff1a;https://www.cnblogs.com/wsg1100/ 实时虚拟化技术是一种针对实时应用场景的虚拟化技术&#xff0c;它要求在保证虚拟化优势…

STM32 ws2812b 最快点灯cubemx

文章目录 前言一、cubemx配置二、代码1.ws2812b.c/ws2812b.h2.主函数 前言 吐槽 想用stm32控制一下ws2812b的灯珠&#xff0c;结果发下没有一个好用的。 emmm&#xff01;&#xff01;&#xff01; 自己来吧&#xff01;&#xff01;&#xff01;&#xff01; 本篇基本不讲原理…

6、传输层TCP28

TCP协议&#xff1a;传输控制协议 1、协议实现 16位源端端口&16位对端端口&#xff1a;描述通信俩端进程32位序号&#xff1a;告诉接收端&#xff0c;这条数据在整体数据中的排序&#xff0c;接收端根据序号进行排序32位确认序号&#xff1a;向发送端进行回复确定&#xff…

pytest-html报告修改与汉化

目录 前言 生成报告 测试代码 原始报告 修改Environment 修改后的效果 修改Summary 修改后的效果 修改Results 优化Test 解决中文乱码 删除多余部分 修改后的效果 删除Links 修改后的效果 增加失败截图与用例描述 完整的conftest.py代码 汉化报告 修改plugin…

ClickHouse进阶

一、Explain查看执行计划 在 clickhouse 20.6 版本之前要查看 SQL 语句的执行计划需要设置日志级别为 trace 才能可以看到&#xff0c;并且只能真正执行 sql&#xff0c;在执行日志里面查看。 在 20.6 版本引入了原生的执行计划的语法。在 20.6.3 版本成为正式版本的功能。 …

常见的JS内置对象——字符串、数学、日期

二、字符串&#xff08;string&#xff09; 创建 一般使用第一种方式 2&#xff09;字符串的遍历 注意&#xff1a;没有foreach方法 3&#xff09;字符串的常见方法 substr()和substring()&#xff1a; substr()参数是从哪个位置开始&#xff0c;截多长 substring()参数是从…

完美匹配:一种简单的神经网络反事实推理学习表示方法

英文题目&#xff1a;Perfect Match: A Simple Method for Learning Representations For Counterfactual Inference With Neural Networks 翻译&#xff1a;完美匹配&#xff1a;一种简单的神经网络反事实推理学习表示方法 单位&#xff1a; 论文链接&#xff1a;https://a…

【状态估计】基于FOMIAUKF、分数阶模块、模型估计、多新息系数的电池SOC估计研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

C++ 创建共享内存

共享内存用于实现进程间大量的数据传输&#xff0c;共享内存是在内存中单独开辟一段内存空间&#xff0c;这段内存空间有自己特有的数据结构&#xff0c;包括访问权限、大小和最近访问时间等。 1、shmget函数 #include <sys/ipc.h> #include <sys/shm.h> int shm…

c++——多态(补充)

优先查看&#xff1a;c——多态_Hiland.的博客-CSDN博客 目录 菱形虚拟继承子类的重写问题 菱形虚拟继承中的偏移量补充 逆向思维——汇编查看多态中被重写的虚函数 菱形虚拟继承子类的重写问题 继承环节时&#xff0c;菱形虚拟继承解决了菱形继承的数据冗余和二义性问题。…

C# Modbus通信从入门到精通(11)——Modbus RTU(调试软件Modbus Slave和Modbus Poll的使用)

前言 我们在开发Modbus程序的时候,会需要测试以下我们写的Modbus程序有没有问题,这时候就需要使用到Modbus Slave和Modbus Poll这两个软件,Modbus Slave是模拟Modbus从站,Modbus Poll是模拟Modbus从站主站的, 1、Modbus Slave 一般情况下我们开发的嗾使Modbus主站程序,…

性能测试(Jemeter)

1.性能指标 响应时间&#xff1a;一次请求的往返时间tps&#xff1a;每秒系统能够处理的事务数&#xff0c;比如订单中的下单操作&#xff0c;下单后续有很多操作&#xff0c;比如创建订单&#xff0c;扣除库存&#xff0c;清算库存等&#xff0c;这个完整操作就是一个完整的事…

【数据分享】1929-2022年全球站点的逐日最大持续风速数据(Shp\Excel\12000个站点)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 对于具体到监测站点的气象数据&#xff0c;之前我们分享过1929-2022年全球气象…