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 灵活就完事了

Vue项目中使用elementUI之Pagination分页组件的二次封装复用

如何基于现有框架的table进行二次封装

利用函数式组件做二次封装

element-UI——el-table二次封装