Elemnt ui 组件封装(table)
<template>
<div class="table">
<el-table
:data="tableData2"
:border="tableConfig.border"
style="min-width: 800px"
:size="tableConfig.size"
:cell-style="tableConfig.cellStyle"
:header-cell-style="tableConfig.headCellStyle"
:stripe="tableConfig.stripe"
>
<slot name="col"></slot>
<el-table-column
v-for="(col, index) in colsData"
:prop="col.prop"
:key="col.prop"
:label="col.label"
:width="tableConfig.colWidth"
>
</el-table-column>
<el-table-column label="操作">
<template slot-scope="scope">
<slot name="operate">
<el-button-group>
<el-button
style="margin-right: 20px"
type="primary"
size="small"
@click="handleEdit(scope.row)"
>编辑</el-button
>
<el-button
type="warning"
size="small"
@click="handleDelete(scope.row)"
>删除</el-button
>
</el-button-group>
</slot>
</template>
</el-table-column>
</el-table>
<el-pagination
style="margin-top: 20px"
v-if="tableConfig.pagination"
:currentPage="currentPage"
:page-size="pageSize"
:page-sizes="[5, 10, 20, 30]"
background
layout="sizes, prev, pager, next"
:total="tableData.length"
@size-change = "handleSizeChange"
@current-change = "handleChange"
>
</el-pagination>
</div>
</template>
<script>
export default {
name: "rTable",
data() {
return {
currentPage: 1,
pageSize: 5
}
},
computed: {
tableData2() {
return this.tableData.slice((this.currentPage-1)*this.pageSize,this.currentPage*this.pageSize);
}
},
props: {
tableData: {
type: Array,
required: true,
},
tableConfig: {
type: Object,
//表单配置
default: function() {
return {
border: true,
size: "small",
cellStyle: { textAlign: "center" },
headCellStyle: { textAlign: "center" },
stripe: true,
colWidth: "180",
//是否显示分页
pagination: true
};
},
},
colsData: {
type: Array,
required: true,
}
},
methods: {
handleEdit: function (row) {
this.$emit("edit", row);
},
handleDelete: function (row) {
this.$emit("delete", row);
},
//页码改变时触发
handleSizeChange: function(val) {
this.pageSize = val;
},
handleChange(val) {
this.currentPage = val;
}
},
mounted() {},
};
</script>
<style lang="scss" scoped></style>
Elemnt ui 组件封装(table)的更多相关文章
- Elemnt ui 组件封装(form)
<template> <el-form class="form" :inline="formConfig.inline" :model=&qu ...
- 前端如何搭建vue UI组件库/封装插件(从零到有)
需求 因之前是做外包项目居多,经常用到相同的组件,之前的办法是在一个项目中写一个组件,其他项目直接将compents下的组件复制,粘贴到项目中使用,缺点是维护起来,改一个项目,其他项目也需要修改,所以 ...
- Vue + Element-ui实现后台管理系统(5)---封装一个Form表单组件和Table表格组件
封装一个Form表单组件和Table组件 有关后台管理系统之前写过四遍博客,看这篇之前最好先看下这四篇博客.另外这里只展示关键部分代码,项目代码放在github上: mall-manage-syste ...
- (Element UI 组件 Table)去除单元格底部的横线
Element UI 组件 Table 有一个属性 border,添加它可以增加纵向边框,但是无法控制横线边框,因此即使是最简单的 el-table,也会包含一个底部横线. 这个底部横线其实是一个 b ...
- Vue + Element UI 实现权限管理系统 (功能组件封装)
组件封装 为了避免组件代码的臃肿,这里对主要的功能部件进行封装,保证代码的模块化和简洁度. 组件结构 组件封装重构后,试图组件结构如下图所示 代码一览 Home组件被简化,包含导航.头部和主内容三个组 ...
- Vue + Element UI 实现权限管理系统 前端篇(七):功能组件封装
组件封装 为了避免组件代码的臃肿,这里对主要的功能部件进行封装,保证代码的模块化和简洁度. 组件结构 组件封装重构后,试图组件结构如下图所示 代码一览 Home组件被简化,包含导航.头部和主内容三个组 ...
- [开源] 基于Layui组件封装的后台模版,HG-Layui-UI通用后台管理框架V1.0版
HG框架简介 HG-Layui-UI框架,是基于layui最新版UI搭建的一套通用后台管理框架,借鉴了市面上各大主流框架风格,采用iframe标签页实现,保留了传统开发模式的简单实用性. 为快速开发减 ...
- 造个自己的Vue的UI组件库类似Element
前言 随着前端的三大框架的出现,组件化的思想越来越流行,出现许多组件库.它能够帮助开发者节省时间提高效率, 如React的Ant-design,Vue的iView,Element等,它们的功能已经很完 ...
- Bootstrap Blazor 组件介绍 Table (一)自动生成列功能介绍
Bootstrap Blazor 是一套企业级 UI 组件库,适配移动端支持各种主流浏览器,已经在多个交付项目中使用.通过本套组件可以大大缩短开发周期,节约开发成本.目前已经开发.封装了 70 多个组 ...
随机推荐
- BUAA 2021-2022毛概复习资料
2021-2022年毛概期末主观题复习范围,参考2022版教材和课程组官方PPT,原文太过敏感,所以贴出代码大家自己run #include <stdio.h> unsigned arti ...
- uniapp小程序图片前端压缩上传
目录 1,前言 2,实现代码 1,前言 这次项目中做了一个图片上传,要求是大于2MB的就压缩成2MB一下的再上传,我这边利用了uniapp的文件接口,使用canvas做了一个压缩上传的功能,目前已上线 ...
- Java中的异常处理机制的简单原理和应用?
程序运行过程中可能出现各种"非预期"情况,这些非预期情况可能导致程序非正常结束. 为了提高程序的健壮性,Java提供了异常处理机制: try { s1... s2... s3... ...
- python 模块和包的基础知识
1.常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀 2.为了方便管理,我们通常将程序分成一个个的文件,这样做程序的结构更清晰,方便管理.这时我们不仅 ...
- python 迭代器和生成器基础知识
1.迭代器遵循迭代器协议:必须拥有__iter__方法和__next__方法--字符串.列表.元组.字典.集合都是可迭代的--可以被for循环的都是可迭代的 2. 迭代器有的好处是可以节省内存 3.生 ...
- Eureka和ZooKeeper都可以提供服务注册与发现的功能,请说说两个的区别?
1.ZooKeeper保证的是CP,Eureka保证的是AP ZooKeeper在选举期间注册服务瘫痪,虽然服务最终会恢复,但是选举期间不可用的 Eureka各个节点是平等关系,只要有一台Eureka ...
- org.apache.kafka.common.errors.SerializationException: Error deserializing... Caused by: org.apache.kafka.common.errors.SerializationException: Size of data received by IntegerDeserializer is not 4
原因,最近开发的kafka消息接收,突然报如下错: org.apache.kafka.common.errors.SerializationException: Error deserializing ...
- Redis Set Type
集合中的元素个数最多为2的32次方-1个,集合中的元素师没有顺序的. Redis集合的操作命令和对应的api如下: smembers [set] JedisAPI:public Set<Stri ...
- 关于css中选择器的小归纳(一)
关于css中选择器的小归纳 一.基本选择器 基本选择器是我们平常用到的最多的也是最便捷的选择器,其中有元素选择器(类似于a,div,body,ul),类选择器(我们在HTML标签里面为其添加的clas ...
- Initialization failed for 'https://start.spring.io
本文精华(没空的小伙伴,直接看精华部分即可) 1.精华1: 开发/下载项目的时候考虑系统必备的版本兼容性 2.精华2: 通过火狐浏览器访问官网的旧版本,下载到任意需要的项目版本,然后通过项目导入ide ...