基于element-ui表格的二次封装实现

在项目中经常会使用到element的表格,如果每次都cv,也确实有点麻烦,基于这个情况我对表格进行了二次封装

写一个Table组件

首先先写表格样式

    <el-table
      :data="tableData"
      :header-cell-style="headerStyle"
      :height="height"
      :border="border"
      @selection-change="handleSelectionChange"
    >
      <el-table-column
        v-if='selection'
        type="selection"
        width="55">
      </el-table-column>
      <el-table-column
        v-for="v in tableProp"
        :key="v.label"
        :prop="v.code"
        :sortable='v.sortable'
        :label="v.label"
        :width="v.width"
      >
        <template slot-scope="scope">
          <div v-if='!v.code'>
            {{ scope.row[scope.column.property] }}
          </div>
          <div v-else>
              <slot name="row" :row="scope.row"></slot>
          </div>
        </template>
        <el-table-column
          v-for="(item, i) in v.data"
          :key="i"
          :sortable='item.sortable'
          align="center"
          :width="item.width"
          :prop="item.code"
          :label="item.label"
        >
          <template slot-scope="scope">
              <div v-if='!v.code'>
                {{ scope.row[scope.column.property] }}
              </div>
              <div v-else>
                  <slot name="row" :row="scope.row"></slot>
              </div>
          </template>
        </el-table-column>
      </el-table-column>
       <el-table-column label="操作" v-if='ishandle'>
        <template slot-scope="scope">
          <slot name="edit" :row="scope.row" :index="scope.$index"></slot>
        </template>
      </el-table-column>
    </el-table>

tableData为当前显示的数据,tableProp为表头的名称,可以为多级也可以为单级,区别为data是否存在,headerStyle为表头样式,height为表的高度,sortable以该列为基准的排序,border是否显示边框,handleSelectionChange多选,selection是否显示多选,ishandle是否显示操作,这里使用插槽进行写操作

export default {
  props: {
    height: {
      type: Number,
      default: 220,
    },
    ishandle:{
      type: Boolean,
      default: false,
    },
    border:{
      type: Boolean,
      default: false,
    },
    tableProp: {
      type: Array,
      default: () => [
        {
          code: 'index',
          label: '指标',
          width: 100,
        },
        {
          code: 'PAC',
          label: 'PAC',
          width: 120,
          data:{
            code: 'PAB',
            label: 'PAB',
            width: 60,
          }
        },
        {
          code: 'PAM',
          label: 'PAM',
          width: 60,
          code:true,
        },
        {
          code: 'POWER_CONSUMPTION',
          label: '综合电耗(kW·h)',
          width: 50,
        },
        {
          code: 'WATER_CONSUMPTION',
          label: '自用水率(%)',
        },
      ],
    },
    tableData: {
      type: Array,
      default:() => [
        {
          index:1,
          PAC:'1'
          PAM:'1',
          POWER_CONSUMPTION:'1',
          WATER_CONSUMPTION:'1'
        }
      ]
    },
    Style:{
      type:String,
      default:'font-size: 12px;padding:0;line-height: inherit;font-weight: 500;color: #6A7474;'
    }
  },
  data() {
    return {
      show: false,
    };
  },
  methods: {
  // 样式
    headerStyle() {
      return this.Style;
    },
    // 多选
    handleSelectionChange(val){
      this.$emit('SelectionChange',val)
    }
  },
};

第二步加分页

<el-pagination
      :background='background'
      :layout="layout"
      :total="total"
      :page-size="pageSize"
      :current-page.sync="current"
      :page-sizes="pageSizes"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :hide-on-single-page='singlepage'
      >
    </el-pagination>

background背景是否显示,layout组件布局,子组件名用逗号分隔,total总条数,pageSizes每页显示个数选择器的选项设置,current当前页码,pageSize每页显示条目个数,singlepage只有一页时是否隐藏,handleSizeChangepageSize 改变时会触发,handleCurrentChange改变时会触发

export default {
  props: {
    background: {
      type: Boolean,
      default: false,
    },
    layout:{
      type: String,
      default: 'total, sizes, prev, pager, next, jumper',
    },
    total:{
      type: Number,
      default: 100,
    },
    pageSize:{
      type: Number,
      default: 10,
    },
    pageSizes:{
      type: Array,
      default: () => [10, 20, 30, 40, 50, 100],
    },
    singlepage: {
      type: Boolean,
      default: false,
    },
    current:{
      type: Number,
      default: 1,
    },
  },
  methods: {
    // pageSize 改变时会触发
    handleSizeChangepageSize (val) {
      this.$emit('handleSizeChangepageSize ',val)
    },
    // currentPage 改变时会触发
    handleCurrentChange(val){
      this.$emit('handleCurrentChange',val)
    }
  },
};

在页面中使用

先引入Table.vue页面

        <Table
          :height="90"
          class="left-top-table"
          :tableData="tableIndex"
          :tableProp="tableProp"
          @handleCurrentChange='handleCurrentChange'
          @handleSizeChangepageSize ='handleSizeChangepageSize '
        >
          <template slot="edit" slot-scope="scope">
            <el-button size="mini" @click="handleEdit(scope.index, scope.row)"
              >编辑</el-button
            >
          </template>
        </Table>
//pageSize 改变时会触发
handleCurrentChange(val){
....
}
// currentPage 改变时会触发
handleSizeChangepageSize (val){
....
}
// 编辑方法
handleEdit(index,row){
....
}

更多的可以根据自己项目的需求进行修改,这只是一个大概的项目雏形

到此这篇关于基于element-ui表格的二次封装实现的文章就介绍到这了,更多相关element表格二次封装内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • vue+element-ui表格封装tag标签使用插槽

    我们知道有很多系统都要求表格中添加各种各样的tag,来标记一些属性.在element-ui中添加tag很简单,最重要的就是用到了vue的插槽slot这个特性.首先了解什么是插槽. 插槽 省去官方的复杂讲解和代码,插槽的意思简单来说,就是在子组件的某个地方留一个占位符,当父组件使用这个子组件的时候,可以自定义这个占位符所占地方呈现的样子,可能是一个标题,一个按钮,甚至一个表格,一个表单. 为什么要插槽呢?我们抽离组件的原因就是因为可重复的代码太多了,当使用可复用的组件时,大大减少了复制粘贴.设想有

  • element el-table表格的二次封装实现(附表格高度自适应)

    前言 在公司实习使用vue+element-ui框架进行前端开发,使用表格el-table较为多,有些业务逻辑比较相似,有些地方使用的重复性高,如果多个页面使用相同的功能,就要多次重复写逻辑上差不多的代码,所以打算对表格这个组件进行封装,将相同的代码和逻辑封装在一起,把不同的业务逻辑抽离出来.话不多说,下面就来实现一下吧. 一.原生el-tbale代码--简单の封装 这里直接引用官方的基础使用模板,直接抄过来(✪ω✪),下面代码中主要是抽离html部分,可以看出每个el-table-column

  • 封装Vue Element的table表格组件的示例详解

    在封装Vue组件时,我依旧会交叉使用函数式组件的方式来实现.关于函数式组件,我们可以把它想像成组件里的一个函数,入参是渲染上下文(render context),返回值是渲染好的HTML(VNode).它比较适用于外层组件仅仅是对内层组件的一次逻辑封装,而渲染的模板结构变化扩展不多的情况,且它一定是无状态.无实例的,无状态就意味着它没有created.mounted.updated等Vue的生命周期函数,无实例就意味着它没有响应式数据data和this上下文. 我们先来一个简单的Vue函数式组件

  • 如何封装Vue Element的table表格组件

    在封装Vue组件时,我依旧会交叉使用函数式组件的方式来实现.关于函数式组件,我们可以把它想像成组件里的一个函数,入参是渲染上下文(render context),返回值是渲染好的HTML(VNode).它比较适用于外层组件仅仅是对内层组件的一次逻辑封装,而渲染的模板结构变化扩展不多的情况,且它一定是无状态.无实例的,无状态就意味着它没有created.mounted.updated等Vue的生命周期函数,无实例就意味着它没有响应式数据data和this上下文. 我们先来一个简单的Vue函数式组件

  • 基于Element封装一个表格组件tableList的使用方法

    我们项目中使用的表格一般都比较类似,如果不进行封装的话,那么每个页面都可能有一些类似的代码.不仅浪费时间,而且由于开发人员不同的开发习惯.后期维护人员需要花费一点时间去看每个人的代码.所以我直接将表格做一个二次封装,只要一个人去维护这份代码即可.下面是我封装的内容 内容: 1.支持直接传入后台请求地址渲染列表,且参数修改之后自动刷新 2.支持自定义每一列的显示 3.支持根据内容自动撑开列宽 4.支持动态筛选表头 5.支持分页 6.防抖 7.列权限 ... 更多请自行尝试 以下是tableList

  • 基于element-ui表格的二次封装实现

    在项目中经常会使用到element的表格,如果每次都cv,也确实有点麻烦,基于这个情况我对表格进行了二次封装 写一个Table组件 首先先写表格样式 <el-table :data="tableData" :header-cell-style="headerStyle" :height="height" :border="border" @selection-change="handleSelectionCha

  • 基于element UI input组件自行封装“数字区间”输入框组件的问题及解决

    目录 问题描述 实现效果 实现代码 问题描述 在开发时遇到一个数字区间输入框的需求,如下图: 项目使用的是vue,组件库用的是element UI,但是element UI并没有提供数字区间组件,只提供了InputNumber 计数器输入框,如果用两个计数器输入框进行拼接也能满足需求,但是样式调试起来太过于复杂且不够灵活,不能令人满意,并且该数字区间输入框在其它界面也有这种需求,于是就在element input输入框的基础上自行封装了一个数字区间组件使用. 实现效果 实现效果如下: 使用方式如

  • Element使用el-table组件二次封装

    目录 前言 一.安装引入 二.封装功能 三.样式覆盖 四.使用组件 前言 在vue开发中使用element-ui的el-table时一般都需要进行封装以便于复用,提高开发效率,减少重复代码,这篇博客对el-table进行简单的二次封装: 一.安装引入 Element官方文档 npm安装element-ui: npm i element-ui -S 可以看文档按需引入,这里为了方便直接全局引入了: import Vue from 'vue' import App from './App.vue'

  • element ui 表格动态列显示空白bug 修复方法

    在使用element ui框架进行项目开发的时候,表格的列是根据后台数据动态生成的,但是发现在列刷新的视乎,会出现表格完全空白,没有显示的情况,经过自己编写demo发现,在增加列的情况下表格正常,但是一旦表格列减少时就会出问题,对element底层代码进行调试发现,在node_modules/element-ui/lib/elementui.common.js 中的一个函数. removeColumn: function removeColumn(states, column) { var _c

  • 解决ant design vue 表格a-table二次封装,slots渲染的问题

    目的就是对a-table进行二次封装,但是在如何显示a-table的slot时遇到了问题,原本想法是在a-table内把$slots都渲染,期望在使用该组件时能正确渲染,然而...并不会正确渲染 <template> <a-table bordered :scroll="{ x: scrollX, y: 600 }" v-bind="{...$attrs, ...$props, ...{dataSource: body, columns: header}}&

  • element ui表格实现下拉筛选功能

    本文实例为大家分享了element ui表格实现下拉筛选的具体代码,供大家参考,具体内容如下 1.default-sort中prop传入要排序的字段(接口返回或自己定义的数据).order代表排序,这里用到降序 2.filters对象中text代表页面中显示的筛选文字,value代表筛选用到的值,在方法中filterHandler用到 3.column 的 key,如果需要使用 filter-change 事件,则需要此属性标识是哪个 column 的筛选条件(绑定的是要对接口中排序的字段) 4

  • 关于element ui 表格中的常见特殊属性说明

    目录 1,表格内容太多用…表示 2,修改element ui自带的样式 3,修改奇数行背景色 4,给表头添加背景色及文字样式 5,表头文字竖向排列(文字带括号) 6,表头边框与文本边框对不齐情况 7,导航栏的侧边栏只展开一个下拉菜单 8,表格表头和内容居中显示 9,添加表格背景色 10,鼠标移入表格高亮显示当前行 element ui 表格的常见特殊属性 1,表格内容太多用...表示2,修改element ui自带的样式3,修改奇数行背景色4,给表头添加背景色及文字样式5,表头文字竖向排列(文字

  • vue axios基于常见业务场景的二次封装的实现

    axios axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中. 在前端框架中的应用也是特别广泛,不管是vue还是react,都有很多项目用axios作为网络请求库. 我在最近的几个项目中都有使用axios,并基于axios根据常见的业务场景封装了一个通用的request服务. npm: $ npm install axios bower: $ bower install axios Using cdn: <script src="https:/

  • Android基于OkHttpUtils网络请求的二次封装

    OkHttpUtils网络请求为什么进行二次封装? 1.减少代码量 2.后期换网络处理框架方便 二次封装的实现原理 1.将网络请求提取在一个方法中 2.对里面的可变参数,可以通过参数传递过去,也可以提供一个set方法传递过去 3.对于请求失败和成功,我们可以使用接口回调,让调用该方法的对象处理 封装后的网络处理类的功能 1.网络请求 2.xml数据转换成javaBean 每一个处理网络请求的ListView都要处理的3数据方法 1.初始化数据 2.下拉刷新数据 3.上拉加载数据 封装前的代码 /

随机推荐