前两天遇到一个问题,不过后来解决啦,在这里跟大家分享一下,话不多说,上案例(基于vue + element)~~~
需求:点击上方表格中的全选/选择,选中数据会显示在下方表格中;
问题:会有重复显示数据
解决办法:
点击全选:会有重复数据所以我们要先去重,
es6中有个去重方法:
this.checkedDataList = Array.from(new Set(this.checkedDataList));
因为上方表格是有分页功能的,所以这个方法可能不是很友好(具体场景:在第一页点击全选,再跳第二页点击全选,再回到第一页,数据就重复了);
然后我又换了一种方法:
const newArr = [];
this.checkedDataList.map((item) => newArr.findIndex(({
id
}) => id === item.id) === -1 && newArr.push(item));
this.checkedDataList = newArr;
这个方法是我在网上找到的(如有侵犯请联系),就完美的解决了我的问题,不管分页如何跳转,下方数据始终不会重复。
点击选择:也会有重复数据的
这个就比较简单了,直接循环,看选中的数据中有没有一模一样的数据好啦,如果有的话就直接提示已经选择此条数据啦!