合并单元格,并且动态合并单元格,合并相同值的单元格,vue2项目

news2025/1/13 10:22:12

element-ui 合并行或列 table :span-method(行合并)_elementui合并列_Take^that的博客-CSDN博客

 


<script>

export default {
    data(){
        return {
            spanArr:[],
            pos:null,
            tableData:[

    },
    mounted(){
        this.getSpanArr(this.tableData)
    },
    methods:{
        objectSpanMethod({row,column,rowIndex,columnIndex}){
            // console.log(row,"<<<=== row");
            // console.log(column,"<<<=== column");
            // if(rowIndex===1){
            //     // 锁定第1行
            //     if(columnIndex===1){
            //         // 锁定第1列
            //         return [1,3]
            //     }else if(columnIndex===2 || columnIndex===3){
            //         return[0,0]
            //     }
            // }

            // if(columnIndex===1){
            //     console.log(rowIndex,"<<<=== rowIndex");
            //     // console.log(column,"column");
            //     // console.log(row,"<<<=== row");
            //     if(rowIndex===0){
            //         return [7,1]
            //     }else if(rowIndex===1 || rowIndex===2 || rowIndex===3 || rowIndex===4 || rowIndex===5 || rowIndex===6){
            //         return [0,0]
            //     }

         
           
            // }

            // if(columnIndex===2){
            //     // console.log(column,"column");
            //     // console.log(row,"<<<=== row");
            //     if(rowIndex===0){
            //         return [7,1]
            //     }else if(rowIndex===1 || rowIndex===2 || rowIndex===3 || rowIndex===4 || rowIndex===5 || rowIndex===6){
            //         return [0,0]
            //     }

         
           
            // }

            if(columnIndex===1 || columnIndex===2 || columnIndex===0){
                // console.log(this.spanArr,"<<<== this.spanArr");
                const _row=this.spanArr[rowIndex]
                console.log(_row,"<<< _row")
                const _col=_row>0 ? 1:0

                return {
                    rowspan:_row,
                    colspan:_col
                }

            }
         
        },
        getSpanArr(tableData){
            // 遍历每个元素
            for(let i=0;i<tableData.length;i++){
                if(i===0){
                    this.spanArr.push(1)
                    this.pos=0

                }else{
                    // 判断当前元素和上一个元素是否相同
                    if(tableData[i].adress===tableData[i-1].adress &&tableData[i].name===tableData[i-1].name){
                        // 相等
                        this.spanArr[this.pos]=this.spanArr[this.pos]+1
                        this.spanArr.push(0)

                    }else{
                        // 不相等
                        this.spanArr.push(1)
                        this.pos=i

                    }
                }
            }

        }
    }
}
</script>


<style scoped lang="scss">

.dialog-box{
    box-sizing:border-box;
    z-index:999;
    position:fixed;
    left:0;
    top:0;
    width:100%;
    height:100%;
    background-color:rgb(0,0,0,0.5);
}

.dialog-bg{
    box-sizing:border-box;
    position:absolute;
    width:1335px;
    height:795px;
    // background-color:pink;
    left:50%;
    top:50%;
    margin-left:-667px;
    margin-top:-397px;
    background-image:url("../../assets/img/dialog.png");
    background-size:100%;
    position:relative;
}

.img-close{
    position:absolute;
    top:4px;
    right:7px;
}

.title-box{
    box-sizing:border-box;
    height:100px;
    width:100%;
    // background-color:pink;
    background-image:url("../../assets/img/dialog-title.png");
    background-repeat:no-repeat;
    background-position:50% 0px;
    text-align:center;
    line-height:100px;
}

.title-text{
    font-size:32px;
    font-family: YouSheBiaoTiHei;
    font-weight: 700;
    color:#fff;
    font-style: italic;
}

.container-box{
    box-sizing:border-box;
    height:calc(100% - 100px);
    width:100%;
    // background-color:pink;
    padding-left:60px;
    padding-right:60px;
    padding-bottom:50px;
    overflow:scroll;
}


</style>

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

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

相关文章

基于若依ruoyi-nbcio支持flowable流程增加自定义业务表单(二)

之前讲了自定义业务表单&#xff0c;现在讲如何与流程进行关联 1、后端部分 WfCustomFormMapper.xml <update id"updateCustom" parameterType"Object">update wf_custom_form set deploy_id #{customFormVo.deployId}, flow_name#{customFormVo.…

MovieLens:一个常用的电影推荐系统领域的数据集

MovieLens是一个常用的电影推荐系统领域的数据集&#xff0c;用于研究和开发推荐算法和机器学习模型。该数据集包含了用户对电影的评分、电影的信息以及用户的信息。以下是MovieLens数据集的完整介绍&#xff1a; MovieLens数据集版本&#xff1a; MovieLens数据集有多个版本…

华为认证 | HCIP-Data Center Network V1.0正式发布!

华为认证数通高级工程师HCIP-Data Center Network V1.0&#xff08;中文版&#xff09;自2023年9月28日起&#xff0c;正式在中国区发布。 01 发布概述 基于“平台生态”战略&#xff0c;围绕“云-管-端”协同的新ICT技术架构&#xff0c;华为公司打造了覆盖ICT领域的认证体系&…

Gossip协议是什么

Gossip协议是什么 Gossip protocol 也叫 Epidemic Protocol (流行病协议), 是基于流行病传播方式的节点或者进程之间信息交换的协议, 也被叫做流言算法, 八卦算法、疫情传播算法等等. 说到 Gossip 协议, 就不得不提著名的六度分隔理论. 简单地说, 你和任何一个陌生人之间所间…

如何做文献笔记

读论文的每一部分都要思考&#xff0c;从该部分中可以我获取到什么信息&#xff1f; 从标题中可以获取到的信息 A技术应用在B领域 B领域之前无人用过机器学习方法 B领域之前有人用过机器学习方法一个新的方法数据集合 论文每个地方从标题到章节都可以读到一些单词、句式进行积…

短视频账号矩阵系统源码saas===独立部署

前言&#xff1a; 短视频账号矩阵是指在不同的短视频平台上&#xff0c;一个个人或企业所拥有的账号数量和分布情况。由于不同的短视频平台受众人群和内容类型等因素不同&#xff0c;因此拥有更多账号可以在更广泛的受众中传播内容&#xff0c;提高曝光度和流量。短视频账号矩阵…

医院门诊排队叫号系统

医院门诊排队叫号系统 1、系统概述&#xff1a; 门诊分诊排队叫号系统是在医院各门诊候诊区域所使用的智能化分诊和排队叫号管理系统&#xff0c;系统可有效地解决病人就诊时排队的无序、医生工作量的不平衡、就诊环境嘈杂等问题。系统具有一级、二级分诊排队模式&#xff0c…

SpringBoot 对接 MinIO 实现文件上传下载删除

前言 MinIO 是一个开源的对象存储服务器&#xff0c;它可以存储大容量非结构化的数据&#xff0c;例如图片、音频、视频、日志文件、备份数据和容器/虚拟机镜像等。 Spring Boot 与 MinIO 的整合可以方便地实现文件的上传和下载等功能 在实际应用中&#xff0c;Spring Boot …

C# 人像卡通化 Onnx photo2cartoon

效果 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; using System.Drawing; using System.Linq; using System.Threading.Tasks; using System.Windows.Forms;nam…

NLP项目:维基百科文章爬虫和分类【02】 - 语料库转换管道

一、说明 我的NLP项目在维基百科条目上下载、处理和应用机器学习算法。相关上一篇文章中&#xff0c;展示了项目大纲&#xff0c;并建立了它的基础。首先&#xff0c;一个 Wikipedia 爬网程序对象&#xff0c;它按名称搜索文章&#xff0c;提取标题、类别、内容和相关页面&…

【毕设选题】深度学习 机器视觉 车位识别车道线检测 - python opencv

0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到毕业答辩的要求&#xff0c;这两年不断有学弟学妹告诉学长自己做的项目系统达不到老师的要求。 为了大家能够顺利以及最少的精力通过…

第二证券:如何选股票的龙头股?

在股票商场中&#xff0c;每个出资者的方针都是可以出资到那些未来可以表现出色并带领整个工作开展的龙头股。选股关于出资者来说非常要害&#xff0c;由于选股不妥或许会导致出资失利。那么&#xff0c;怎么选股票的龙头股呢&#xff1f;本文从多个角度进行剖析&#xff0c;协…

platformIO开发arduino

第一先安装arduino,再在arduino库里面安装第三方库。然后下载vscode,在vscode上安装platformIO&#xff0c;然后点击Quick Access下的Import Arduino Project 然后选择自己的arudino项目&#xff0c;一般在用户的Document下面 进入带有.ino后缀的文件夹里然后点击import就可以将…

C语言每日一题(10) 回形矩阵

题目链接 分析思路 我采用的设计思路是从外围开始向里面赋值&#xff0c;关键在于循环的判断条件&#xff0c;从外围的上下左右行依次赋值&#xff0c;然后再向里继续。 1.取得中心值的方法是&#xff1a;用n/2再向上取整&#xff0c;注意类型的转换&#xff0c;因为如果是整…

软件工程与计算总结(六)需求分析方法

本贴介绍需求分析方法&#xff0c;涉及到诸多实践性的东西&#xff0c;掌握各种图表的绘制是重中之重~ 一.需求分析基础 1.原因 需求获取中得到的信息仅仅解释了用户对软件系统的理解与期待&#xff0c;使用的是实际业务的表达方式&#xff0c;还不是开发者能够立即加以实现…

Ubuntu20.04安装Ipopt的流程介绍及报错解决方法(亲测简单有效)

本文主要介绍在Ubuntu20.04中安装Ipopt库的流程&#xff0c;及过程报错的解决方法&#xff0c;已经有很多关于Ipopt安装的博客&#xff0c;但经过我的测试&#xff0c;很多都失效了&#xff0c;因此&#xff0c;经过探索&#xff0c;我找到可流畅的安装Ipopt的方法&#xff0c;…

一站式数据可视化与分析平台JVS智能BI强大的数据节点功能

在商业智能&#xff08;BI&#xff09;中&#xff0c;数据集是数据的集合&#xff0c;用于分析和报告。数据节点是数据集中的一个重要组成部分&#xff0c;它代表数据集中的一个特定数据点或数据元素。通过使用数据节点&#xff0c;可以对数据进行过滤、分组和计算&#xff0c;…

Netty通信在中间件组件中的广泛使用-Dubbo3举例

Netty是一个高性能异步IO通信框架&#xff0c;封装了NIO&#xff0c;对各种bug做了很好的优化解决。所以很多中间件底层的通信都会使用Netty&#xff0c;比如说&#xff1a;Dubbo3&#xff0c;rocketmq&#xff0c;ElasticSearch等。 比方说&#xff0c;我们使用dubbo作为rpc跨…

批量混剪系统视频闪闪批量剪辑:只需几段素材片段即可批量混剪大量成片,快速制作大量成片的秘密

视频闪闪批量混剪系统&#xff1a;快速制作大量成片的秘密 在今天这个视频内容爆炸的时代&#xff0c;如何快速处理大量的素材并生成优质的成片&#xff0c;是许多视频制作人员面临的挑战。而视频闪闪批量混剪系统&#xff0c;却能帮助你轻松解决这一难题。 视频闪闪批量混剪…

Qt多工程同名字段自动翻译工具

开发背景 项目里不同工程经常会引用同一批公共类&#xff0c;这些类里如果有字段需要翻译&#xff0c;需要在不同的项目里都翻译一遍&#xff0c;比较麻烦冗余。 特此开发了这个小翻译工具&#xff0c;能读取程序目录下的所有ts文件&#xff0c;以类名归类&#xff0c;不同项目…