zoukankan      html  css  js  c++  java
  • el-table表格中需要计算金额合计,合计的金额如果过长需要溢出隐藏并且显示title

    问题描述

    在一个表格中需要计算金额合计,合计的金额如果过长需要溢出隐藏并且显示title

    <!-- index 是tableData循环的下标-->
    <el-table ref="tableRef" :data="tableData" show-summary :summary-method="val => summaries(val, index)" ></el-table>
    
    // 解决表格合计行不显示
    updated() {
    	this.$nextTick(() => {
    	   this.$refs.tableRef.doLayout();
    	})
    }
    

    合并数据并在合计行使用v-title指令

    /**
     * @Description: 合并数据
     * @param {*} param
     * @return {*}
     */
    getSummaries(param, idx) {
      const { columns, data } = param
      const sums = []
      if (!Array.isArray(columns)) return
    
      columns.forEach((column, index) => {
        if (index === 1) {
          sums[index] = '合计'
          return
        }
    
        const key = column.property
        const sPam = ['gAmount', 'oAmount', 'cTotal']
        if (sPam.includes(key)) {
          const values = data.map(item => Number(item[key]))
          if (!values.every(value => isNaN(value))) {
            sums[index] = values.reduce((prev, curr) => {
              const value = Number(curr)
              if (!isNaN(value)) {
                return prev + curr
              } else {
                return prev
              }
            }, 0)
            
            // 这里插入标签
            sums[index] = (() => {
              return <span v-title>{value2Text(sums[index], 'area')}</span>
            })()
          } else {
            sums[index] = ''
          }
        }
      })
      return sums
    }
    

    使用回车标签显示两行合并的数据

    summaries(param, idx){
    	const { columns, data } = param
    	const sums = []
    	columns.forEach((column, index) => {
    		if (index === 0) {
    			sums[index] = (()=>{
    				return <p>total<br/><br/>discount</p>
    			})()
    		}
    		if (index === 3) {
    			sums[index] = (()=>{
    				return <p>{this.tableData[idx].dPrice}
                    <br/><br/>{this.tableData[idx].vPrice}</p>
    			})()
    		}
    	})
    	return sums
    }
    
  • 相关阅读:
    NHibernate 转载
    net中Json对单引号和特殊字符串的处理
    C#过滤非法字符
    Linq Distinct 扩展
    (转)Windows启动过程分析预引导
    special content filetypes require specialized software to use
    存储器
    (转)MAPISendMail调用系统默认的邮件客户端发邮件
    FrameControllerModel
    (转)c++的四种类型转换
  • 原文地址:https://www.cnblogs.com/codebook/p/15379748.html
Copyright © 2011-2022 走看看