首页前端开发VUEvue element-ui el-table组件自定义合计(summary-method)的坑

vue element-ui el-table组件自定义合计(summary-method)的坑

时间2024-02-11 04:49:02发布访客分类VUE浏览335
导读:收集整理的这篇文章主要介绍了vue element-ui el-table组件自定义合计(summary-method 的坑,觉得挺不错的,现在分享给大家,也给大家做个参考。 目录ele...
收集整理的这篇文章主要介绍了vue element-ui el-table组件自定义合计(summary-method)的坑,觉得挺不错的,现在分享给大家,也给大家做个参考。
目录
  • element-ui el-table组件自定义合计(summary-method)坑
  • element-ui中的el-table组件时,自定义合并表头和合并行
    • 1、合并相同数据的行
    • 2、自定义合并表头
  • 总结

    element-ui el-table组件自定义合计(summary-method)坑

    项目需要用到表格,带有合计功能的,照搬的element-ui的table组件,但是合计就是不出来

    因为表格是客操作的,所以都是用的自定义内容

    自定义的方法也是官方的

    后面找问题发现,红框圈住的地方一直是undefined,才发应过来,在表格上应该需要写 PRop的,完了写了

    改成这样,每一列需要计算的都加了,就ok了

    希望对遇到问题的童鞋一个帮助!

    element-ui中的el-table组件时,自定义合并表头和合并行

    在使用element-ui中的el-table组件时,怎么自定义合并表头和合并行

    1、合并相同数据的行

    效果图如下,合并相同名称的行

    代码如下:

    data(){
    		return{
    			tableData1:[{
    a:6}
    ,{
    a:12}
    ,{
    a:7}
    ,{
    b:6}
    ,{
    b:7}
    ,{
    c:44}
    ]		}
    }
        

    在el-table头中加入:span-method=“arraySpanMethod”,span-method:合并行或列的计算方法

    // 合并列筛选    flITterData (arr) {
              let spanOneArr = []      let concatOne = 0      arr.foreach((item, index) =>
     {
            if (index === 0) {
                  spanOneArr.push(1);
            }
     else {
                  if (item &
        &
         arr[index - 1] &
        &
     item.a === arr[index - 1].a) {
         // 第一列需合并相同内容的判断条件            spanOneArr[concatOne] += 1;
                    spanOneArr.push(0);
              }
     else {
                    spanOneArr.push(1);
                    concatOne = index;
              }
            }
          }
        );
          return {
            one: spanOneArr      }
        }
    ,    // 合并相同列    arraySpanMethod ({
     row, column, rowIndex, columnIndex }
    ) {
          if (columnIndex === 0) {
                let data = [];
                data = this.tableData1;
                const _row = (this.flitterData(data).one)[rowIndex];
                const _col = _row >
         0 ? 1 : 0;
            return {
              rowspan: _row,          colspan: _col        }
        ;
          }
        }
        ,

    2、自定义合并表头

    table自带合并属性:rowSpan和colSpan,所以合并表头的思路是:获取所有的表头单元格,针对性的对需要合并的单元格进行操作。

    类似下面这种表头的合并

    比如我们想要合并的是第n列和第n+1列,那么我们先获取到所有的表头,然后将第n列表头的colSpsn设为2,将第n+1列表头的display设为none。

    备注:

    • el-table__header:是你table的class名,自定义,也可以使用vue中的ref去定义,然后使用this.$refs.xxx去拿到
    • .rows[0]是拿到table的第一行(rows行)
    • cells:中文的意思是:单元格。就是我们获取一行(rows)后,这一行中有多少单元格,一行中所有的单元格集合,可以理解cells为这个行的第几列
    • colSpan:跨多少列(单元格自带的属性)
    • display:none可以隐藏某个元素,且隐藏的元素不会占用任何空间。该元素不但被隐藏了,而且该元素原本占用的空间也会从页面布局中消失。
    methods: {
        setColSpan:function() {
          //this.$refs.el-table__header      // console.LOG(document.getElementsByclassname("el-table__header"))      // 获取表头的所有单元格      let n = document.getElementsByClassName("el-table__header")[0].rows[0].cells      // 将第二列表头单元格的colSpan设为2      n[1].colSpan = 2      // 将第三列表头单元格的display设为none      n[2].style.display = 'none'    }
    ,}
    ,mounted() {
        // 注意一定要保证DOM渲染完成后在进行合并操作,否则会找不到元素    this.$nextTick(function(){
              this.setColSpan();
        }
    )}
        

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

    您可能感兴趣的文章:
    • vue element-ui中table合计指定列求和实例
    • vue3使用element-plus中el-table组件报错关键字'emitsOptions'与'insertBefore'分析
    • vue项目配置element-ui容易遇到的坑及解决

    声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


    若转载请注明出处: vue element-ui el-table组件自定义合计(summary-method)的坑
    本文地址: https://pptw.com/jishu/609340.html
    vue3.0 vant popup渲染不出来问题及解决 vuex的几个属性及其使用传参方式

    游客 回复需填写必要信息