对element-ui的table组件的二次封装
首先,使用过element-ui的table组建的同学都知道,每次使用的时候表头字段都要一个一个的去写,写起来很麻烦,既不美观又浪费时间,基于以上原因,对table组件进行二次封装,使我们在使用的时候更加简单方便。
这里只是简单的封装,同学们若是感兴趣可以加以完善,若有问题可以一起讨论。
//封装的table组件
<template>
<!-- 列表 -->
<el-table
stripe
:border="border"
:data="dataSource"
@selection-change="handleSelectionChange"
v-loading="listLoading"
@row-dblclick="rowClick"
highlight-current-row
@row-click="clickTable"
ref="refTable"
@expand-change="expandChange"
>
<!--数据源-->
<el-table-column
v-for="(column, index) in columns"
header-align="center"
v-if="column.isShow"
:sortable="column.hasSort"
:key="column.prop"
:prop="column.prop"
:label="column.label"
:align="column.align"
:width="column.width">
</el-table-column >
</el-table>
</template>
<script>
export default {
name:"tables",
props:{
dataSource: {// 表格数据源 默认为空数组
type: Array,
default: ()=> []
},
columns: {// 表格的字段展示 默认为空数组
type: Array,
default: ()=>[]
}
},
components: {
//
},
watch:{
//
},
mounted(){
//
},
methods: {
//
}
}
</script>
<style lang="scss">
//
</style>
封装完成后怎么调用这个组件呢?
//调用封装好的table组件
<template>
//这里仅传入列表数据和表头数据,如有其它需求可以增加传递参数
<tables :dataSource="dataSource" :columns="columns"></tables>
</template>
<script>
import tables from './table.vue' //引入组件
export default {
data() {
return {
dataSource:[{
'createTime':123,
'times':123,
'username':'jj',
'deptName':'ii',
'status':'0',
},{
'createTime':123,
'times':123,
'username':'jj',
'deptName':'ii',
'status':'0',
},{
'createTime':123,
'times':123,
'username':'jj',
'deptName':'ii',
'status':'0',
}],
columns:[{
hasSort: false, //<Boolean> 是否排序
isShow: true, //<Boolean> 是否展示
prop: 'createTime', //<String> 对应属性名
label: '日期', //<String> 表头标签
align: 'center',//表头内容是否居中
width: 200, // 列宽
},{
hasSort: false, //<Boolean> 是否排序
isShow: true, //<Boolean> 是否展示
prop: 'times', //<String> 对应属性名
label: '时间', //<String> 表头标签
align: 'center'//表头内容是否居中
},{
hasSort: true, //<Boolean> 是否排序
isShow: true, //<Boolean> 是否展示
prop: 'username', //<String> 对应属性名
label: '名字', //<String> 表头标签
align: 'center'//表头内容是否居中
},{
hasSort: true, //<Boolean> 是否排序
isShow: true, //<Boolean> 是否展示
prop: 'deptName', //<String> 对应属性名
label: '部门名称', //<String> 表头标签
align: 'center'//表头内容是否居中
},{
hasSort: true, //<Boolean> 是否排序
isShow: true, //<Boolean> 是否展示
prop: 'status', //<String> 对应属性名
label: '状态', //<String> 表头标签
align: 'center'//表头内容是否居中
}
]
}
},
components: {
tables,//注册table组件
},
watch:{
//
},
mounted(){
//
},
methods: {
//
}
}
</script>
<style lang="scss">
//
</style>
下面是我的公众号二维码,欢迎同学们关注,大家一起学习,一起进步。

对element-ui的table组件的二次封装的更多相关文章
- vue问题三:element ui的upload组件上传图片成功和移除事件
element ui的upload组件上传图片成功和移除事件: 登录后获取到后台传的token存到中: sessionStorage.setItem("token",data.ob ...
- Vue+element UI实现分页组件
介绍 这是一个是基于element-UI的分页组件基础上,进行了二次封装的分页组件,在展示数据时,该分页组件采用了每显示一页数据,只请求当前页面的数据的请求策略,从而避免了一次性将数据全部请求所造成的 ...
- vue+element ui项目总结点(二)table合计栏目,按照起始年份--截止年份 插入数据并向后追加数据以最后一条年份+1
1.oninput 事件在用户输入时触发; <template> <div class="test_box"> <p>hell,你好</p ...
- 关于Element UI中select组件中遇到的问题
问题一:在使用select组件设置多选功能后,窗口抖动问题? 详细描述:在我使用select做多选的功能时出现了窗口抖动的问题,测试的时候发现,在有些人的电脑上抖动,有些人的电脑上不抖,找了很多文档, ...
- react ,ant Design UI中table组件合并单元格并展开详情的问题
需求:购物车订单列表,如图: 一:单元格合并 遇到这种你会怎么办呢? 单元格合并? 还是其他的方法? 下面是我的处理方式,就是在table 组件的columns上处理,这里拿商品举例,其余的类似, ...
- 09 - Vue3 UI Framework - Table 组件
接下来做个自定义的表格组件,即 table 组件 返回阅读列表点击 这里 需求分析 开始之前我们先做一个简单的需求分析 基于原生 table 标签的强语义 允许用户自定义表头.表体 可选是否具有边框 ...
- vue+element ui中select组件选择失效问题原因与解决方法
codejing 2020-07-10 09:13:31 652 收藏 分类专栏: Web Vue Element UI 版权 .当表单form赋完值后,如果后续又对form中某一属性值进行操作如 ...
- Bootstrap Blazor Table 组件(二)
原文链接:https://www.cnblogs.com/ysmc/p/16128206.html 很多小伙伴在使用 Bootstrap Blazor Table组件的时候,都会有这样的一个需求: 我 ...
- 基于bootstrap table配置的二次封装
准备 jQuery js css 引用完毕 开始 如果对bootstrap table 的方法与事件不熟悉: Bootstrap table方法,Bootstrap table事件 <table ...
随机推荐
- 解决Vue3使用 Ant Design,出现多个Modal,全是黑屏,导致列表页看不见问题!
尴尬问题 不报错,但是我看着就难受. 求知路上 请教了下强哥,强哥告诉我可能某个样式属性失效引起(无效),建议我F12看下样式. 接着,我F12狂看元素样式,查了一个小时未果,我真抓狂了. 都想明天问 ...
- 「CTSC 2011」排列
「CTSC 2011」排列 要求不存在公差为 A 或者公比为 B 的子列,那么实际上可以把该问题转化为求一个图的最优拓朴序. 任意差为 A 或者比为 B 的两个数连一条边. 求一个合法序列的答案可以用 ...
- Python起航
安装Python 安装python 添加python安装目录到PATH 添加Scripts目录到PATH 如果同时安装了python2和python3,那么通过python和python3,pip和p ...
- Solution -「CF 908D」New Year&Arbitrary Arrangement
\(\mathcal{Description}\) Link. 给定 \(n,p_a,p_b\),初始有一个空串,每次操作有 \(\frac{p_a}{p_a+p_b}\) 的概率在其后添加字 ...
- Dubbo源码剖析六之SPI扩展点的实现之getExtensionLoader
Dubbo SPI机制之三Adaptive自适应功能 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中,示例案例中自定义了扩展接口而不是使用Dubbo已提供的扩展接口.在案例中,主程序分 ...
- Spring AOP基础概念及自定义注解式AOP初体验
对AOP的理解开始是抽象的,看到切点的匹配方式其实与正则表达式性质大致一样就基本了解AOP是基本是个什么作用了.只是整个概念更抽象,需要具化理解.下图列表是AOP相关概念解释,可能也比较抽象^_^ 比 ...
- ios开发 将json格式数据上传服务器
看了一些大小牛的资料其实就3步 1.使用post 请求 ,因为get是不能上传的 2.设置请求类型 , 讲你的json数据上传 3.向服务器发送数据按照下面示例代码,就差不多了 1 // 1.创建请求 ...
- ios开发 Pods工具心得
Pods 这也是我的第一篇微博,希望能给大家带来帮助,也便于我自己温习 第一步:新建一个xcode项目(这个不解释了) 第二步:打开终端(剩下的操作都在终端里面了)
- blender导入灰度图生成地形模型
安装软件 在此处下载blender并安装. 添加平面 1.打开blender,右键删除初始的立方体. 2.shift+a选择平面添加进场景: 3.按下s键鼠标拖动调节平面大小确定后按下鼠标左键: 4. ...
- Java基础问题
基础问题 谈谈你对面向对象的理解 -- 结合场景 为何要使用对象编程? 可重复利用,方便拓展 面向对象有三大特征:封装.继承和多态 封装:为什么要封装?可以使类的成员(数据和行为)有选择性的暴露,这里 ...