el-table实现可编辑表格的思路;el-table删除不正确:表格中的el-select下拉数据项有值,但输入框中value值不显示

news2024/11/30 10:33:26

目录

一、问题

二、原因及解决方法

 三、总结


tips:如嫌繁琐,直接看总结即可!

一、问题

el-table实现可编辑表格的思路:

1.要写一个可编辑的表格:表格中的一列是下拉框。实现方法很简单:在el-table-column(elemen提供了插槽)中插入 下拉框el-select,就可以正常显示了(其他组件或者自定义组件也可以随便插入,都能够正常显示)

2.增加和删除操作

   1)增加:表格数据tableData写成响应式的,在tableData中push数据就可以

    2)  删除:点击表格的行时,拿到elemen提供的插槽数据:当前点击的行 scope.$index;删除的时候直接在tableData中找到下标为 scope.$index的删除即可。

3.其实思路还是挺简单的;写的差不多了,测试一把,没想到还出问题了@--@

   具体问题;在el-table中插入了很多行,下拉框所在的单元格选择不同的值。然后执行删除操作,1-3行数据的时候没有问题,4行及以上数据就出问题了,我点击删除了一行,结果把和这一行相邻的行里面下拉框本来选中的 值弄没了,但是下拉项中有对应的值,并且样式也是选中的样式再次选中 有选中样式的下拉数据,仍然无法填充到 el-select的input输入框中,选其他值是没有问题的,可以正常填充!!!!具体情况如下图1-1所示。

图 1-1 

二、原因及解决方法

1..在html中显示el-select绑定的value值,看到el-select绑定的value是 有值的。就离谱,不带这么完的。

2.因为那个下拉框并不是我自己写的,是别人封装过的,我以为是别人封装的有问题;自己换成了element提供的el-select:重复 一、3中的操作,还是出现了下拉项中有对应的值;下拉框中选中的值 没了,不过,这次再选中 有选中样式的下拉数据时,el-select的input输入框能够正常填充。(诶,那个组件确实有一点问题吧,但是不是这次讨论的重点)

3.检查我写的删除方法:啊,我又犯错误,一边删除数组,一边按照初始的数组下标去找数据。无语了,这个错误真的是犯了不下三次了。虽然也不是这次问题的原因(因为我只删除一行,完全能删除掉的,删除多行这种写法就是作死),但是也是 导致删除有问题的一个原因!希望下次不要错了。

4.在devtools用Vue插件检查了一下,el-input的值真的没有了@****@,如图2-1所示

图 2-1

5..为什么,我删一条数据,会影响其他数据呢?为什么只有下拉框所在的单元格有问题?天哪,不理解,就离谱!!!加班加班@—@

6.郁闷了一个多小时。最后想到上次 勾选几条数据,el-table的全选按钮竟然被选中了。猜测是不是el-table又分不清哪条数据是哪条了,所以我删了谁,它也是不清不楚,稀里糊涂的

7.竟然真的被我猜对了,每条数据加上唯一的 row-key标识后,竟然没有问题了,如图2-2所示!!!!!!

就离谱呀。用el-table最好保证row-key必填,且el-table的data中的每一条数据对应的row-key都是唯一的;不然很可能导致各种离谱的错误呀!!!

图 2-2

 三、总结

1.可编辑表格思路:

   1)el-table-column(elemen提供了插槽)中插入 可以编辑的组件(下拉框、输入框等)即可

   2)增加和删除操作

          a.增加:表格数据tableData写成响应式的,在tableData中push数据就可以

          b.删除:点击表格的行时,拿到elemen提供的插槽数据:当前点击的行 scope.$index;删除的时候直接在tableData中找到下标为 scope.$index的删除即可。

2.el-table删除时没有被删除的行受到删除行的影响的原因: 

    1)检查你的删除逻辑是否正确,特别是批量删除的时候,不要一边删除,一边在数组里面找原来的下标删除;你永远删不完的;用一个临时变量来存储不需要删除的,然后赋值给tableData就可以了!

    2)检查你是否给每行数据添加唯一的标识字段rowKey,并且赋值为el-table(:row-key="rowKey");可以在删除的时候判断一下每条数据如果没有唯一标识,可以手动设置一个,比如设置为数组的下标 (如rowKey为'id’,则每条数据添加 element.id=elementIndex)

3.使用el-table最好保证row-key必填,且el-table的data中的每一条数据对应的row-key都是唯一的;不然很可能导致各种离谱的错误呀。

     1)表格最上角半选中样式失效;具体可参考:el-table部分选中时,显示全选样式,class:is-indeterminate丢失原因及解决方法_琹箐的博客-CSDN博客

      2)删除表格的行影响了其他行的数据:本文

4.天天踩坑,吃一堑长一智,快些成长吧&&**&&

/*
希望对你有帮助!

如有错误,欢迎指正,非常感谢!

*/ 

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

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

相关文章

PMP课堂模拟题目及解析(第9期)

81. 一位经验丰富的项目经理在到达一个重大开发里程碑之前识别到一个问题,项目经理采取相应的行动,并能够按时解决问题。两周后,发起人通知项目经理,客户发出了处罚费。若要避免这个问题,项目经理应该事先做什么&…

FGX Native 1.4.1.1 For Delphi Crack

FGX Native 1.4.1.1 For Delphi Crack FGX Native Network Frame是制造跨平台和现代移动设备的强大工具。FG开发团队的主要目标是简化移动应用程序的开发,使大多数人都能以各种技能开发应用程序。此外,这种形式的网络最重要的功能可以在100%的用户界面中…

CorelDRAW2020工作室版下载及新增功能介绍

CorelDRAW Graphics Suite 2020将基于人工智能的图形设计提升到一个全新水平。CorelDRAW 中增强了“查找和替换”\“对齐和分布”、阴影效果等功能。您喜欢的 Corel PHOTO-PAINT 功能 — 从遮罩、效果和透镜到“替换颜色”— 均已优化! 针对操作系统的功能优化 Core…

微信之小程序授权登录

首先我要怒骂微信的后台开发 真的还是乱七八糟。 首先我们登录微信开发平台 选择要开发的类型 然后小程序登录:选择 微信小程序实现微信登录详解(JAVA后台)官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework…

玩转ChatGPT:魔改文章成果格式

一、写在前面 首先,我让小Chat替我吐槽一下: 科研人员天天都在填各种表格,简直成了我们的“表格王子”和“表格公主”。从申请项目、提交论文到汇报成果,表格无处不在。我们填表格的时候总是期待着它能让我们的工作更高效、更顺…

Redis 内存消耗及回收

Redis 是一个开源、高性能的 Key-Value 数据库,被广泛应用在服务器各种场景中。Redis 是一种内存数据库,将数据保存在内存中,读写效率要比传统的将数据保存在磁盘上的数据库要快很多。所以,监控 Redis 的内存消耗并了解 Redis 内存…

tinyWebServer 学习笔记——四、日志系统

文章目录 一、基础知识1. 概念2. API 二、代码解析1. 单例模式2. 阻塞队列3. 日志类定义4. 生成日志文件并判断写入方式5. 日志分级与分文件 参考文献 一、基础知识 1. 概念 流程图 [2] 日志:由服务器自动创建,用于记录运行状态和错误信息;同…

C++系列六:运算符

C运算符 1. 算术运算符2. 关系运算符3. 逻辑运算符4. 按位运算符5. 取地址运算符6. 取内容运算符7. 成员选择符8. 作用域运算符9. 总结 1. 算术运算符 算术运算符用于执行基本数学运算,例如加减乘除和取模等操作。下表列出了C中支持的算术运算符: 运算…

JSON+AJAX+ThreadLocal+文件上传下载

文章目录 JSON和AJAX文档介绍1. JSON介绍1.1 JSON快速入门1.2 JSON和字符串转换1.2.1 JSON转字符串1.2.2 字符串转JSON1.2.3 JSON和字符串转换细节 1.3 JSON在java中使用1.3.1 Java对象和JSON字符串转换1.3.2 List对象和JSON字符串转换1.3.3 Map对象和JSON字符串转换 2. Ajax介…

DAY 58 数据库的存储引擎

存储引擎的概念 什么是存储引擎 MySQL中的数据用各种不下同的技术存储在文件中,每一种技术都使用不同的存储机制、索引技巧、锁定水平并最终提供不同的功能和能力,这些不同的技术以及配套的功能在MySQL中称为存储引擎。 存储引擎是MySQL将数据存储在文…

JUC之volatile

作用:volatile是Java提供的一种轻量级的同步机制 保证内存可见性 不保证原子性 防止指令重排序 public class VolatileDemo {private static int num0;public static void main(String[] args) {new Thread(()->{while (num0){}},"A").start();try {…

Spark大数据处理讲课笔记4.6 Spark SQL数据源 - JDBC

文章目录 零、本讲学习目标一、Spark SQL读取关系数据库二、Spark SQL JDBC连接属性三、创建数据库与表(一)创建数据库(二)创建学生表(二)创建成绩表 四、读取和写入数据库表(一)利用…

力扣第 104 场双周赛 2681. 英雄的力量

原题链接力扣 题目大意:我开始看成连续子段了,写了个递归程序....... 一个数组任选一个子序列,子序列的力量值最大值平方*最小值。求所有子序列的力量和。 分析过程:如序列长度为n,子序列总数为2的n次幂&#xff0c…

SpringCloud------zookeeper代替Eureka,zookeeper版本冲突解决(七)

SpringCloud------zookeeper代替Eureka(七) SpringCloud整合zookeeper代替Eureka 注册中心zookeeper zookeeper是一个分布式协调工具,可以实现注册中心功能 关闭Linux服务器防火墙后,启动zookeeper服务器 zookeeper服务器取代Eur…

mac桌面文件删除怎么恢复?别急,有办法!

大家是不是习惯于将临时要用的文件都存放在桌面上。虽然文件放在桌面上,可以方便我们随时调取,但是也容易出现误删除的情况,给我们带来麻烦。mac桌面文件删除怎么恢复?希望通过本篇教程,你能找回误删除的桌面文件。 案…

script标签type值application/json,importmap和module

type(默认text/javascript) 该属性定义 script 元素包含或src引用的脚本语言。属性的值为 MIME 类型(媒体类型); 如果没有定义这个属性,脚本会被视作 JavaScript。 如果 MIME 类型不是 JavaScript 类型&a…

GPT4结对编程实战,鹅厂一线研发真实使用感受

👉腾小云导读 ChatGPT4相比ChatGPT3.5在逻辑推理能力上有很大的进步,其代码生成能力颇为优越。因此作者尝试在工作中某些不涉密的基础工作上,应用ChatGPT4来提升研发效率,简单尝试之后发现其在不少场景是有效的。本文将向大家展示…

元宇宙又“死”了!Epic老板:你当6亿用户是摆设?

“扎克伯格花了数年时间试图让Metaverse成为现实,但现在它已被AI取代,并走向科技创意的坟墓。”一篇表达“元宇宙已死”的文章近期在推特上引发热议,而游戏制作公司Epic Games CEO Tim Sweeney的还击更是让这个话题热上加热。 “搞一次在线守…

【SSL证书】使用mkcert创建局域网或单机可信任Windows格式证书

初学者对SSL证书的理解可能非常模糊。所谓SSL证书,其实它包含两个方面,一是根证书,二是HTTPS的证书,HTTPS证书合法性由其根证书来进行认定。几大证书供应商的根证书一般都预置在系统中了,所以给人的错觉就是只知HTTPS证…

深入解析 Facebook 分析工具,洞察用户行为和优化策略

作为一名 Facebook 运营者,了解用户行为和优化策略是至关重要的。在本文中,我们将深入解析Facebook 分析工具,帮助你更好地洞察用户行为和优化策略。 1.Facebook 像素 Facebook 像素是一个重要的工具,可以帮助运营者了解用户在网…