elementUI table二次封装
Posted dyy-dida
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了elementUI table二次封装相关的知识,希望对你有一定的参考价值。
1.html
<template> <el-table ref="table" element-loading-text="Loading" :data="tableData" border tooltip-effect="dark" style="width:100%"> <el-table-column v-for="(item,index) in tableLabel" :width="item.width ? item.width : ‘‘" :key="index" :align="item.align" :label="item.label" :prop="item.param" :sortable="item.sortable ? ‘custom‘ : false"> <template slot-scope="scope"> <span v-if="item.render"> item.render(scope.row) </span> <span v-else>scope.row[item.param]</span> </template> </el-table-column> <el-table-column v-if="tableOption.label" :width="tableOption.width" :label="tableOption.label" align="center" class-name="small-padding fixed-width"> <template slot-scope="scope"> <el-button v-for="(item,index) in tableOption.options" :key="index" :type="item.type" :icon="item.icon" @click="handleButton(item.methods,scope.row,scope.row)" size="mini"> item.label </el-button> </template> </el-table-column> </el-table> </template>
2.子组件中js
<script> export default props: tableData: type:Array, default: () => return [] , tableLabel: type:Array, default: () => return [] , tableOption: type:Object, default: () => return , components:, methods: </script>
3.父组件调用
<table-cmp :table-data="tableData" :table-label="tableLabel" :table-option="tableOption" ></table-cmp>
4.父组件js
tableData:[], tableLabel: [ label: ‘用户名‘, param: ‘usr‘, align: ‘center‘,sortable:true , label: ‘公司名称‘, param: ‘company‘, align: ‘center‘ , label: ‘办公邮箱‘, param: ‘email‘, align: ‘center‘,width:‘200‘ , label: ‘注册时间‘, param: ‘registTime‘, align: ‘center‘,sortable:true , label: ‘审核状态‘, param: ‘status‘, align: ‘center‘,sortable:true, render: (row) => if (row.status === 0) return ‘未审核‘ else if (row.status === 1) return ‘审核通过‘ else if(row.status ===2) return ‘审核不通过‘ else return ‘禁用‘ ], tableOption: label: ‘操作‘, width: ‘200‘, options: [ label: ‘预览‘, type: ‘primary‘, icon: ‘el-icon-view‘, methods: ‘preview‘ , label: ‘审核‘, type: ‘primary‘, icon: ‘el-icon-upload2‘, methods: ‘audit‘ , ]
二次封装,将所有的信息动态生成。
以上是关于elementUI table二次封装的主要内容,如果未能解决你的问题,请参考以下文章
vue-form-table(vuejs+element-ui的表格表单控件的二次封装插件)
vue中二次封装elementUi的弹出框MessageBox 灵活就完事了