zoukankan      html  css  js  c++  java
  • vue 选中列表去重

    前两天遇到一个问题,不过后来解决啦,在这里跟大家分享一下,话不多说,上案例(基于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;

             

             这个方法是我在网上找到的(如有侵犯请联系),就完美的解决了我的问题,不管分页如何跳转,下方数据始终不会重复。

       点击选择:也会有重复数据的

              这个就比较简单了,直接循环,看选中的数据中有没有一模一样的数据好啦,如果有的话就直接提示已经选择此条数据啦!

          

  • 相关阅读:
    Flask初识之安装及HelloWord程序
    Python 四大主流 Web 编程框架
    Mysql之锁、事务绝版详解---干货!
    Django基础九之中间件
    Django基础八之cookie和session
    Django基础七之Ajax
    Django基础六之ORM中的锁和事务
    Linux下使用tail查找日志文件关键词有颜色、高亮显示
    主流云测平台汇总
    RPC框架总述
  • 原文地址:https://www.cnblogs.com/houBlogs/p/11138170.html
Copyright © 2011-2022 走看看