【原生HTML】表格

news2025/1/9 17:03:44

1、一个表格合并后多选

我这里的表格是在elementUI的tabs页里的,所以数据格式多了一层

数据格式

 html原生代码:

    <table
                class="multi-table"
                style="width: 100%; border-color: #ebeef5"
                border="1px"
                cellspacing="0"
              >
                <thead>
                  <tr>
                    <th>
                      <input
                        id="js-all-checkbox"
                        type="checkbox"
                        @click="checkAll(this)"
                      />
                    </th>
                    <th>序号</th>
                    <th>产品名称</th>
                    <th>商标</th>
                    <th>型号规格</th>
                    <th>产品批号/编号</th>
                    <th>数量</th>
                    <th>生产日期</th>
                    <th>备注</th>
                    <th>产品大类</th>
                    <th>产品类型</th>
                    <th>检测标准</th>
                    <th>检测项目</th>
                  </tr>
                </thead>
                <tbody
                  style="text-align: center"
                  v-for="(item, index) in sample_list"
                  :key="index"
                >
                  <tr>
                    <td :rowspan="item.items.length + 1">
                      <input
                        type="checkbox"
                        name="select"
                        :value="index"
                        @click="clickCheckbox(item, index)"
                      />
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.no }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.cpmc }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.sb }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.xhgg }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.cpbhph }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.sl }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.scrq }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.remark }}
                    </td>
                  </tr>
                  <tr v-for="(value, i) in item.items" :key="i">
                    <td>
                      {{ value.cpdl }}
                    </td>
                    <td>
                      {{ value.cplx }}
                    </td>
                    <td>
                      {{ value.jcbz }}
                    </td>
                    <td>
                      {{ value.jcxm }}
                    </td>
                  </tr>
                </tbody>
              </table>
data:{
    checkValues: [], //原生表格多选选中的索引数组
},
methods:{
   // 原生多选
    clickCheckbox(item, index) {
      var checkDomArr = document.querySelectorAll(
        ".multi-table tbody input[type=checkbox]:checked"
      );
      this.checkValues = []; //选中的数组

      for (var i = 0, len = checkDomArr.length; i < len; i++) {
        this.checkValues.push(checkDomArr[i].value);
      }

      var allCheckDomArr = document.querySelectorAll(
        ".multi-table tbody input[type=checkbox]"
      );
      var allCheckbox = document.getElementById("js-all-checkbox");
      for (var i = 0, len = allCheckDomArr.length; i < len; i++) {
        if (!allCheckDomArr[i].checked) {
          if (allCheckbox.checked) allCheckbox.checked = false;
          break;
        } else if (i === len - 1) {
          document.getElementById("js-all-checkbox").checked = true;
          return;
        }
      }
    },
    // 原生全选
    checkAll(current) {
      //  其余的多选框
      var allCheckDomArr = document.querySelectorAll(
        ".multi-table tbody input[type=checkbox]"
      );
      // 全选框
      var allcheckbox = document.getElementById("js-all-checkbox");
      this.checkValues = [];
      // 点击的时候, 状态已经修改, 所以没选中的时候状态时true
      if (!allcheckbox.checked) {
        for (var i = 0, len = allCheckDomArr.length; i < len; i++) {
          var checkStatus = allCheckDomArr[i].checked;
          if (checkStatus) allCheckDomArr[i].checked = false;
        }
      } else {
        for (var i = 0, len = allCheckDomArr.length; i < len; i++) {
          var checkStatus = allCheckDomArr[i].checked;
          if (!checkStatus) allCheckDomArr[i].checked = true;
          this.checkValues.push(allCheckDomArr[i].value);
        }
      }
    },
}

2、多个表格循环合并

 

 <div>
            <div v-for="(j, idx) in group" :key="idx">
              <div
                style="
                  font-weight: 600;
                  font-size: 16px;
                  height: 35px;
                  line-height: 35px;
                  padding: 0 10px 0;
                  width: 100%;
                  background-color: #fff;
                "
              >
                {{ j.name }}
              </div>
              <table
                style="width: 100%; border-color: #ebeef5"
                border="1px"
                cellspacing="0"
              >
                <thead>
                  <tr>
                    <th>序号</th>
                    <th>产品名称</th>
                    <th>商标</th>
                    <th>型号规格</th>
                    <th>产品批号/编号</th>
                    <th>数量</th>
                    <th>生产日期</th>
                    <th>备注</th>
                    <th>产品大类</th>
                    <th>产品类型</th>
                    <th>检测标准</th>
                    <th>检测项目</th>
                  </tr>
                </thead>
                <tbody
                  style="text-align: center"
                  v-for="(item, index) in j.sample_list"
                  :key="index"
                >
                  <tr>
                    <td :rowspan="item.items.length + 1">
                      {{ item.no }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.cpmc }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.sb }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.xhgg }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.cpbhph }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.sl }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.scrq }}
                    </td>
                    <td :rowspan="item.items.length + 1">
                      {{ item.remark }}
                    </td>
                  </tr>
                  <tr v-for="(value, i) in item.items" :key="i">
                    <td>
                      {{ value.cpdl }}
                    </td>
                    <td>
                      {{ value.cplx }}
                    </td>
                    <td>
                      {{ value.jcbz }}
                    </td>
                    <td>
                      {{ value.jcxm }}
                    </td>
                  </tr>
                </tbody>
              </table>
            </div>
          </div> 

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

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

相关文章

使用IDEA时关于Tomcat处理HTML请求乱码的问题(通过访问服务器的静态页面F12后响应头里的编码格式都是utf-8了,还是乱码)

解决方法在文末&#xff0c;大家可以下滑到底部直接浏览 今天在使用Tomcat访问静态页面时&#xff0c;页面出现乱码问题&#xff0c;各种办法的试了&#xff0c;内心一度处于奔溃的边缘&#xff0c;在外出跑步冷静了一下之后&#xff0c;思路渐渐清晰。 出现乱码后的第一步&a…

C数据结构与算法——顺序表 应用

实验任务 (1) 掌握顺序表结构及其 C 语言实现&#xff1b; (2) 掌握插入、删除等基本算法&#xff1b; (3) 掌握顺序表的基本应用&#xff08;将两个有序线性表合并为一个有序表&#xff09;。 实验内容 使用 C 语言实现顺序表的类型定义与算法函数&#xff1b;编写 main()函…

Verilog parameter的用法

parameter简介 parameter”是Verilog HDL中的一个关键字&#xff0c;代表着参数型常量&#xff0c;即用parameter来定义一个标识符代表一个常量&#xff0c;这样可以提高程序的可读性与可维护性。 parameter应用场景 #&#xff08;parameter number500&#xff09; 表示定义一…

零代码开发平台免费,未来企业数字化转型常用工具

什么是零代码开发平台 零代码开发平台指的是一种软件开发工具&#xff0c;能够使开发人员在不编写代码的情况下构建应用程序或快速应用程序。它们一般是通过拖放的方式创建用户界面&#xff0c;配置业务逻辑&#xff0c;集成数据库等操作&#xff0c;节省开发周期和人力成本。…

安森美-深力科NC7SV08P5X能成为极高速、高驱动和低功耗应用的理想选择吗?

描述&#xff1a; 关于安森美-深力科NC7SV08P5X是飞兆超低功率 (ULP-A) TinyLogic 系列的一个 2 输入“与”门。 ULP-A 是要求极高速、高驱动和低功耗应用的理想选择。 用于宽低电压工作范围&#xff08;0.9 V 到 3.6 V VCC&#xff09;&#xff0c;适合驱动和速度要求高于 Ti…

需求分析的概念和原则

概念和原则 需求分析是指在软件开发和项目管理中&#xff0c;通过收集、理解、分析和记录用户和系统对系统或产品的需求&#xff0c;以确定其详细的特征和功能。它是一个关键的过程&#xff0c;旨在确保项目成功地满足用户的需求和期望。 在进行需求分析时&#xff0c;有一些…

常用数据聚类算法总结记录

本文的主要目的是总结记录日常学习工作中常用到的一些数据聚类算法&#xff0c;对其原理简单总结记录&#xff0c;同时分析对应的优缺点&#xff0c;以后需要的时候可以直接翻看&#xff0c;避免每次都要查询浪费时间&#xff0c;欢迎补充。 聚类算法是一种无监督学习的方法&am…

Docker安装 Nginx

相关文章&#xff1a; Docker容器之间的连接和通信(四)_做测试的喵酱的博客-CSDN博客 一、 Docker安装 Nginx 1.1、查看可用的 Nginx 版本 docker search nginx 1.2、安装最新 Nginx 版本 docker pull nginx:latest 1.3 查看本地镜像 docker images 1.4 运行容器 运行…

架构-新教材补充内容

系统工程 两分&#xff0c;需要计算的选择题 #mermaid-svg-opoH5AvD05BTqVHp {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-opoH5AvD05BTqVHp .error-icon{fill:#552222;}#mermaid-svg-opoH5AvD05BTqVHp .error-te…

关系型数据库全栈入选唯一厂商!GBASE南大通用的“可信”时刻

作为国产数据库的领军企业&#xff0c;业界公认的“可信”力量&#xff0c;GBASE南大通用深度参与大会&#xff0c;与各协会领导、学术大咖、技术领军共同论道我国数据库自立自强之路。 现在让我们一起盘点为期两天的议程中GBASE南大通用的“高光”时刻&#xff0c;且看GBASE是…

7.7工作总结

一、前言&#xff1a;这周三领导让我修改一个入库接口&#xff0c;需要加入三个参数&#xff0c;我直接把相应的数据加进去了忽略了这个参数是放在一个List中的同时还需要转成json的形式。因此我又修改了一遍。 二、错误的形式&#xff1a; 在接口文档中是这样的形式&#xff…

最新版Flink CDC MySQL同步Elasticsearch(一)

1.环境准备 首先我们要基于Flink CDC MySQL同步MySQL的环境基础上&#xff08;flink-1.17.1、Java8、MySQL8&#xff09;搭建Elasticsearch7-17-10和Kibana 7.17.10。笔者已经搭建好环境&#xff0c;这里不做具体演示了&#xff0c;如果需要Es的搭建教程情况笔者其他博客 注意…

【案例教程】GPT模型支持下的Python-GEE遥感云大数据分析、管理与可视化技术及多领域案例实践实践技术

随着航空、航天、近地空间等多个遥感平台的不断发展&#xff0c;近年来遥感技术突飞猛进。由此&#xff0c;遥感数据的空间、时间、光谱分辨率不断提高&#xff0c;数据量也大幅增长&#xff0c;使其越来越具有大数据特征。对于相关研究而言&#xff0c;遥感大数据的出现为其提…

海格里斯HEGERLS智能四向穿梭车系统是如何赋能企业降本增效的?

随着人工智能和物联网等新技术的更新迭代&#xff0c;物流行业数字化&#xff0c;智能仓储已成趋势。我国智能仓储在“互联网”战略的带动下快速发展&#xff0c;与大数据、云计算等新一代互联网技术深度融合&#xff0c;智能仓储整个行业向着运行高效、便捷、低成本的方向迈进…

Vision Transformer推理中线性-角度注意转换压缩自注意

文章目录 Castling-ViT: Compressing Self-Attention via Switching Towards Linear-Angular Attention at Vision Transformer Inference摘要本文方法实验结果 Castling-ViT: Compressing Self-Attention via Switching Towards Linear-Angular Attention at Vision Transform…

Angular 调试工具(Augury)

目录 1、简介 2、检验代码 3、Angury 本地构建和安装 3.1 添加到Chrome 浏览器&#xff1a; 3.2 添加到Firefox浏览器 4、项目中对应的Npm脚本 5、Augury 三大主要功能 5.1 组件树&#xff08;Component Tree&#xff09; 5.1.1 Component Tree 5.2 路由树&#xff0…

HarmonyOS学习路之开发篇—数据管理(对象关系映射数据库)

HarmonyOS对象关系映射&#xff08;Object Relational Mapping&#xff0c;ORM&#xff09;数据库是一款基于SQLite的数据库框架&#xff0c;屏蔽了底层SQLite数据库的SQL操作&#xff0c;针对实体和关系提供了增删改查等一系列的面向对象接口。应用开发者不必再去编写复杂的SQ…

港联证券|如何区分大盘股和小盘股?

1、依据个股的市值来区别。一般来说&#xff0c;大盘股&#xff1a;流转市值在500亿及以上&#xff0c;小盘股&#xff1a;流转市值一般在50亿及以下&#xff0c;市值在二者之间的被称为中盘股。 2、依据流转股本区别。一般来说&#xff0c;大盘股&#xff1a;流转股本大于5亿&…

mysql重点复习

1.MySQL如何对用户smart授权访问&#xff0c;密码为123456。 2.授权用户tom可以在网络中的192.168.4.254主机登录&#xff0c;仅对对userdb库下的user表有查看记录、更新name字段的权限 &#xff0c; 登录密码userweb888。 GRANT SELECT,UPDATE(name) ON userdb.user TO tom192…

零拷贝小结

零拷贝&#xff08;Zero-copy&#xff09;是一种优化技术&#xff0c;用于减少数据传输过程中的拷贝操作&#xff0c;从而提高系统性能和效率。在传统的数据传输中&#xff0c;涉及多个缓冲区之间的数据拷贝操作&#xff08;例如从磁盘到内存的拷贝、内存到网络缓冲区的拷贝等&…