vue使用table实现动态数据报表(行合并)

news2024/10/11 19:29:55

<template>
  <div class="previewTable">
    <h2>***项目研发数据报告</h2>
   
    <table id="previewTable" width="100%">
      <tr>
        <th>项目名称</th>
        <td colspan="6">{{ resultData.proName }}</td>
        <th>课程级别</th>
        <td>{{resultData.leval }}</td>
      </tr>
      <tr>
        <th>课题类别</th>
        <td colspan="4"></td>
        <th>目标方向</th>
        <td></td>
        <th>承担部门</th>
        <td></td>
      </tr>
      <tr>
        <th>项目负责人</th>
        <td colspan="3"></td>
        <th>项目成员</th>
        <td colspan="5"></td>
       
      </tr>
      <tr>
        <th>委托</th>
        <th colspan="3">方案</th>
        <th>样品</th>
        <th colspan="2">检验项目</th>
        <th colspan="2">方案小结</th>
      </tr>
      <tr v-for="(item) in resultData.list" :key="item.id">
        <td v-if="item.commissionRowSpan != 0" :rowspan="item.commissionRowSpan">{{item.commission}}</td>
        <td v-if="item.schemeRowSpan != 0" :rowspan="item.schemeRowSpan">{{item.scheme}}</td>
        <td v-if="item.schemeNameRowSpan != 0" :rowspan="item.schemeNameRowSpan">{{item.schemeName}}</td>
        <td>
          <span class="link-class" >数据链接</span> 			 
        </td>
        <td v-if="item.schemeNameRowSpan != 0" :rowspan="item.schemeNameRowSpan">{{item.num}}</td>
       
        <td>{{item.inspectionItems}}</td>
        <td>
          <span class="link-class" >数据链接</span> 			 
        </td>
        <td>
          ***小结(小结名称)
							 
        </td>
        <td>
          <span class="link-class" >数据链接</span> 			 
        </td>
      </tr>
    </table>
     
  </div>
</template>
<script>
export default{
  data(){
    return{
      resultData:{
        proName:"xxx项目名称",
        leval:'高级',
        zhengshus:"安全员C证、PMP",
        list:[
          {
            id:0,
            commission:"委托1",
            scheme:"委托1方案1",
            schemeName:"委托1方案1(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"直读检测成分",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:0,
            commission:"委托1",
            scheme:"委托1方案1",
            schemeName:"委托1方案1(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"金相组织",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:0,
            commission:"委托1",
            scheme:"委托1方案1",
            schemeName:"委托1方案1(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"晶粒度评级",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:0,
            commission:"委托1",
            scheme:"委托1方案1",
            schemeName:"委托1方案1(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"硬度测量",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:0,
            commission:"委托1",
            scheme:"委托1方案2",
            schemeName:"委托1方案2(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"直读检测成分",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:1,
            commission:"委托1",
            scheme:"委托1方案2",
            schemeName:"委托1方案2(方案名称)",
            num:"5",
            name:"李四",
            inspectionItems:"金相组织",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:2,
            commission:"委托1",
            scheme:"委托1方案3",
            schemeName:"委托1方案3(方案名称)",
            num:"5",
            name:"王五",
            inspectionItems:"晶粒度评级",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:3,
            commission:"委托2",
            scheme:"委托2方案1",
            schemeName:"委托2方案1(方案名称)",
            num:"5",
            name:"何佳慧",
            inspectionItems:"硬度测量",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:4,
            commission:"委托2",
            scheme:"委托2方案2",
            schemeName:"委托2方案2(方案名称)",
            num:"5",
            name:"王五",
            inspectionItems:"常温冲击",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:5,
            commission:"委托2",
            scheme:"委托2方案3",
            schemeName:"委托2方案3(方案名称)",
            num:"5",
            name:"何佳慧",
            inspectionItems:"金相组织",
            zhengshus:"安全员A证、操作员B证"
          },
          {
            id:6,
            commission:"委托3",
            scheme:"委托3方案1",
            schemeName:"委托3方案1(方案名称)",
            num:"5",
            name:"何佳慧",
            inspectionItems:"常温冲击",
            zhengshus:"安全员A证、操作员B证"
          }
        ]
      }
     

    }
		
  },
  created() {
    this.combineRow(['commission','scheme','schemeName'])
			
  },
  methods:{
    //  合并单元格
    combineRow(cols) {
      console.log("resultData.value",this.resultData.list)
      const tableData = this.resultData.list
      cols.forEach((key) => {
        for (let i = 0; i < tableData.length; i++) {
          const item = tableData[i]
          let count = 1
          for (let j = i + 1; j < tableData.length; j++) {
            // 如果是同一个值,往后递增
            if (item[key] === tableData[j][key]) {
              count++
              // 往后相同的值都设为空单元格
              tableData[j][`${key}RowSpan`] = 0
              // 只有同值第一个才设置合并的单元格数
              item[`${key}RowSpan`] = count
              // 所有都是为同一个值的情况
              // 如果到了尾部,则循环结束
              if (j === tableData.length - 1) {
                return
              }
            } else {
              // 指针跳转到下一个,从下一排开始
              i = j - 1
              count = 1
              tableData[j][`${key}RowSpan`] = count
              break
            }
          }
        }
      })
      this.resultData.list = tableData
    }
		
  }
}

</script>



<style lang="scss" scoped>
 .previewTable{
	 padding:10px;
	 background-color: #fff;
	 color: #000000;
	 line-height: 40px;
	 h2{
		text-align: center;
	 }
	 .link-class{
		color: red;
	 }
	 // 给表格设置边框
	 table,
	 td,
	 th {
		 text-align: center;
		 border: 1px solid #ccc;
		 border-collapse: collapse;
	 }
	 table td {
		 // padding: 10px 30px;
	 }
 }  
 
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2205614.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux_kernel中断系统13

一、温故知新 1、字符设备编程框架 什么是字符设备&#xff1f; 在Linux操作系统中文件类型为.c文件&#xff0c;称为字符设备文件 按字节访问 访问的顺序是固定的 1&#xff09;struct cdev结构 实现一个硬件字符设备的驱动程序时&#xff0c;实际上就是实例化一个stru…

闪迪U盘误删的数据该怎么恢复呢?3个方法轻松解决

闪迪是一家全球知名的美国公司&#xff0c;也是全球最大的闪存数据存储卡产品供应商&#xff0c;其中&#xff0c;闪迪U盘作为其主要产品之一&#xff0c;因其便携性、大容量和高速传输能力而深受用户喜爱。然而&#xff0c;在平时存储重要数据的时候&#xff0c;会因为我们一系…

Ngin入门套餐

快速了解Nginx 一、代理1.1 正向代理1.2 反向代理1.3 正向代理和反向代理的区别 二、Nginx负载均衡策略2.1 轮询&#xff08;Round Robin&#xff09;2.2 加权轮询&#xff08;Weighted Round Robin&#xff09;2.3 IP 哈希&#xff08;IP Hash&#xff09;2.4 最少连接&#x…

C语言 | Leetcode C语言题解之第462题最小操作次数使数组元素相等II

题目&#xff1a; 题解&#xff1a; static inline void swap(int *a, int *b) {int c *a;*a *b;*b c; }static inline int partition(int *nums, int left, int right) {int x nums[right], i left - 1;for (int j left; j < right; j) {if (nums[j] < x) {swap(…

Spring17——Spring事务简介、使用事务实现模拟转账业务

38-Spring事务简介 相关概念 事务作用&#xff1a;在数据层保障一系列的数据库操作同成功同失败Spring事务作用&#xff1a;在数据层或业务层保障一系列的数据库操作同时成功或同时失败 数据层有事务我们可以理解&#xff0c;为什么业务层也需要处理事务呢&#xff1f;举个简…

黑马点评(更新中)

黑马点评 1、短信登录 Session实现1.1 分析1.2、Session实现的缺点1.3、其中的问题1.3.1、session覆盖1.3.2、在拦截之后remove User的作用 2、用Redis实现短信登录2.1 分析2.2 代码以及问题2.2.1 String问题2.2.2 刷新问题2.2.3 注入对象问题2.2.4 拦截器order问题 3、缓存3.1…

6个设计师都在用的样机素材网站

设计师都在哪里找样机素材&#xff1f;推荐6个样机素材网站&#xff0c;免费下载&#xff0c;赶紧收藏好&#xff01; 1、菜鸟图库 样机图片素材-样机图片模板免费下载 - 菜鸟图库 菜鸟图库有多种类型的设计素材&#xff0c;像平面、电商、UI、办公等素材这里面都能找到&#…

若依-二级页面的跳转设计

配置二级路由页面&#xff0c;就是点击了某个按钮之后会跳转到一个页面中去&#xff0c;比如需要点击查看详情的时候就可以进行页面的跳转。 点击字典类型 进入到字典数据页面。这个页面在左侧是没有的&#xff0c;在导航栏会有展示出来。 在index.js中配置的代码 //path 当前的…

从新手到专家,Tableau Agent 如何满足不同用户的分析需求?

为什么要构建 Tableau Agent&#xff1f;Tableau 对话式 AI 助理如何助你加速分析&#xff1f; 正在查询相关数据和现有仪表板&#xff0c;看看能否解答业务问题&#xff1f; 还在持续准备、管理和编辑数据&#xff0c;以确保企业数据的质量和可访问性&#xff1f; 希望快速创…

SDH8323非隔离12V/15V/18V,300MA直插DIP7电源芯片

SDH8323 是高压启动&#xff0c;内置高压MOSFET的电流模式PWMPFM控制器&#xff0c;适用于Buck及Buck-Boost拓扑。 SDH8323 在轻载条件下降频工作&#xff0c;优化轻载条件下的转换效率。在极轻载及空载条件下工作于打嗝模式&#xff0c;从而有效地降低系统的待机功耗。 SDH832…

DIFY上使用多种大语言模型(MindCraft API)

注册MindCraft并创建API KEY 首先我们在智匠MindCraft上注册账号并创建API KEY&#xff0c;参考接口调用文档&#xff0c;查看我们能调用哪些模型。我们可以看到这个开发平台上整合了主流的大语言模型&#xff0c;并且是兼容openai接口的。 进入DIFY的设置界面 然后我们在DIFY上…

为何一个简单的线上商城 两年销售7000多万?

有一个销售百货的商城&#xff0c;他们的返现模式极为独特且富有吸引力。无论你消费多少&#xff0c;商城都会随机给你返还一定金额的钱&#xff0c;这个返还范围从10元到1000元不等&#xff0c;确实非常随意。 那么&#xff0c;这个商城采用如此随性的返现模式&#xff0c;业绩…

软件性能测试有哪些测试指标?性能测试第三方软件测评中心推荐

作为衡量软件质量的重要指标之一&#xff0c;软件的性能是一种非功能特性&#xff0c;不关心系统是否可以完成特定的功能&#xff0c;而只关心软件系统在运行时的速度是否足够快、是否消耗足够少的资源&#xff0c;因此软件性能测试至关重要。性能测试是指软件测试人员根据产品…

监控台操作台在哪些企业中应用比较广泛

在现代企业管理中&#xff0c;监控台操作台作为一种集成了视频监控、音频监听、数据分析及远程控制等多种功能的综合性操作平台&#xff0c;正逐渐成为众多企业不可或缺的重要设备。其广泛的应用领域不仅提升了企业的运营效率&#xff0c;还极大地增强了企业的安全性能。 一、安…

淘宝程序员没活硬整?在 Excel 和 VSCode 中购物!

大家好&#xff0c;我是程序员鱼皮&#xff0c;最近某宝网站的改进&#xff0c;属实是有点 “新” 了。 你敢相信这是一个购物网站么&#xff1f; 你可以在 Excel 表格中挑选商品进行购物&#xff0c;还原度极高&#xff0c;这两个图表更是点睛之笔。哪个天才想出来的&#xf…

C++Linux项目推荐-Web多人聊天+MySQL+Redis+Websocket+Json,可以写简历的C++项目

1 项目地址 项目配套视频简介&#xff1a;程序员老廖的个人空间-程序员老廖个人主页-哔哩哔哩视频 (bilibili.com) 1.1 项目原有功能 https://github.com/anarthal/servertech-chat.git 功能&#xff1a; 支持HTTP请求&#xff0c;掌握HTTP API json的请求相应 支持Webso…

如何使用ssm实现疫情居家办公OA系统

TOC 10902ssm疫情居家办公OA系统 系统概述 进过系统的分析后&#xff0c;就开始记性系统的设计&#xff0c;系统设计包含总体设计和详细设计。总体设计只是一个大体的设计&#xff0c;经过了总体设计&#xff0c;我们能够划分出系统的一些东西&#xff0c;例如文件、文档、数…

手机怎么玩荒野大镖客2?GameViewer远程助你手机随时随地畅玩大表哥2

手机免费玩电脑游戏&#xff0c;原来手机也能随时随地玩荒野大镖客2&#xff1f;如果你想你手机随时随地畅玩大表哥2&#xff0c;可以使用网易GameViewer远程来实现。 GameViewer远程4K蓝光144帧的高画质&#xff0c;可以让你在玩荒野大镖客2时&#xff0c;体验到开放大世界的所…

2024年11月软考准考证什么时候打印?

打印时间一览表&#xff1a; 北京&#xff1a;2024年11月5日至11月8日 上海&#xff1a;2024年11月6日10:00至11月8日16:00 天津&#xff1a;2024年11月5日9:00后 重庆&#xff1a;2024年11月4日9:00至10日9:05 广东&#xff1a;2024年11月5日9:00至8日17:00 深圳&#xf…

靠“代工+营销”支撑,又突击分红10亿元,毛戈平冲刺上市为哪般

撰稿|行星 来源|贝多财经 10月9日&#xff0c;毛戈平化妆品股份有限公司&#xff08;下称“毛戈平”或“毛戈平公司”&#xff09;在港交所更新招股书&#xff0c;继续推进港股上市进程。此前&#xff0c;毛戈平曾于4月8日向港交所递表&#xff0c;但因财务资料已过有效期而“…