vue3+ts数组去重方法-reactive/ref响应式显示

news2024/11/24 19:18:29

vue3+ts数组去重方法-reactive/ref响应式显示

本文目录

    • vue3+ts数组去重方法-reactive/ref响应式显示
      • 简单数组
        • 使用 Set 和 扩展运算符(...)将集合转换回数组
        • 使用 Set 和 Array.from() 方法将集合转换回数组
        • 使用 filter 和 indexOf 进行判断
        • 使用 splice 和 indexOf 进行判断
        • 使用 map 进行判断,需要新建数组存储
        • 使用 includes 进行判断,需要新建数组存储
      • 对象数组
        • 使用冒泡排序的前后对比 和 splice,原地修改
        • 使用 object 判断 key ,新建数组存储
        • 利用 reduce 方法遍历数组,可原地修改
        • 利用 map 方法遍历数组,可原地修改
      • 关于响应式
        • 失去响应式
        • 保持响应式

简单数组

  • 数组使用reactive定义(推荐)
var arr: number[] = reactive([1, 2, 3, 4, 5, 6, 1, 2, 3])

// 变量都替换为arrX.ar
var arrX = reactive({
  ar: [1, 2, 3, 4, 5, 6, 1, 2, 3]
})
  • 数组使用ref定义
// 变量都替换为ar.value
var ar = ref([1, 2, 3, 4, 5, 6, 1, 2, 3])

使用 Set 和 扩展运算符(…)将集合转换回数组

const noRepeat1 = function () {
  arr = [...new Set(arr)];
  console.log("...set  " + newArr);
}
...set  1,2,3,4,5,6

使用 Set 和 Array.from() 方法将集合转换回数组

const noRepeat1 = function () {
  arr = Array.from(new Set(arr));
  console.log("Array.from  " + arr);
}
Array.from  1,2,3,4,5,6

使用 filter 和 indexOf 进行判断

const noRepeat2 = function () {
  // 检查指定数组中符合条件的所有元素
  arr = arr.filter(function (item, index) {
    return arr.indexOf(item) === index;  // 因为indexOf 只能查找到第一个  
  });
  console.log("filter-indexOf  " + arr);
}
filter-indexOf  1,2,3,4,5,6

使用 splice 和 indexOf 进行判断

const noRepeat3 = function () {
  // 原地修改
  for (let i = 0; i < arr.length; i++) {
    if (arr.indexOf(arr[i]) != i) {
      arr.splice(i, 1);//删除数组元素后数组长度减1后面的元素前移
      i--;  //数组下标回退
    }
  }
  console.log("原地 splice  " + arr);
}
原地 splice  1,2,3,4,5,6

使用 map 进行判断,需要新建数组存储

var newArr: number[] = reactive([]);
const noRepeat4 = function () {
  newArr.length = 0;  //如果newArr已经有值,需要置空
  // 创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素
  let map = new Map();
  arr.forEach((item) => {
    if (!map.has(item)) {
      map.set(item, true)
      newArr.push(item)
    }
  })
  console.log("map  " + newArr);
}
map  1,2,3,4,5,6

使用 includes 进行判断,需要新建数组存储

var newArr: number[] = reactive([]);
const noRepeat5 = function () {
  // 创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素
  arr.forEach((item) => {
    if (!newArr.includes(item)) {
      newArr.push(item)
    }
  })
  console.log("includes  " + newArr);
}
includes  1,2,3,4,5,6

对象数组

  • 使用reactive定义
// 给arrOb赋值,但reactive永远是响应式的(推荐)
const state = reactive({
  arrOb: [
    { key: '01', value: '乐乐' },
    { key: '02', value: '博博' },
    { key: '03', value: '淘淘' },
    { key: '04', value: '哈哈' },
    { key: '01', value: '乐乐' },
  ],
});

// 直接赋值操作可能会导致失去响应式的效果
const state2 = reactive([
  { key: '01', value: '乐乐' },
  { key: '02', value: '博博' },
  { key: '03', value: '淘淘' },
  { key: '04', value: '哈哈' },
  { key: '01', value: '乐乐' },
]);

使用冒泡排序的前后对比 和 splice,原地修改

const noRepeatObject0 = function () {
  for (let i = 0; i < state.arrOb.length - 1; i++) {
    for (let j = i + 1; j < state.arrOb.length; j++) {
      if (state.arrOb[i].key == state.arrOb[j].key) {
        state.arrOb.splice(j, 1);
        //因为数组长度减小1,所以直接 j++ 会漏掉一个元素,所以要 j--
        j--;
      }
    }
  }
  console.log("挨个对比 - object list")
  console.log(state.arrOb)
};

使用 object 判断 key ,新建数组存储

使用 object 对象访问属性的方法,判断对象中是否存在key,新建数组存储

interface Item {
  key: string;
  value: string;
}

var stateRes: Item[] = reactive([])
type stringKey = Record<string, boolean>
const noRepeatObject1 = function () {
  var obj: stringKey = {};
  for (let i = 0; i < state2.length; i++) {
    if (!obj[state2[i].key]) {
      stateRes.push(state2[i]);
      obj[state2[i].key] = true;
    }
  }
  console.log("obj - object list")
  console.log(stateRes)
};

利用 reduce 方法遍历数组,可原地修改

interface Item {
  key: string;
  value: string;
}

type stringKey2 = Record<string, number>
const noRepeatObject2 = function () {
  var obj: stringKey2 = {};
  state.arrOb = state.arrOb.reduce(function (item, next) {
    obj[next.key] ? '' : obj[next.key] = true && item.push(next);
    return item;
  }, [] as Item[]);
  console.log("reduce - object list")
  console.log(state.arrOb)
};

利用 map 方法遍历数组,可原地修改

const noRepeatObject3 = function () {
  let map = new Map();
  for (let item of state2) {
    if (!map.has(item.key)) {
      map.set(item.key, item);
    }
  }
  // 数组定义:reactive([]);  reactive({ arr: [] });
  // xx.length = 0;
  // xx.push(...map.values());

  // 数组定义:reactive({ arr: [] });
  state4.arrOb = [...map.values()];

  console.log("map - object list")
  console.log(state2)
};
  • 全部结果

关于响应式

const dataArray1 = reactive({ arr: [] }); // 创建一个响应式对象,其中包含一个空数组
const dataArray2 = reactive([]); // 创建一个响应式数组

dataArray1.arr = [1, 2, 3]; // 这样赋值后,dataArray1.arr 仍然是响应式的,因为它仍然是 reactive 对象的一部分
dataArray2 = [1, 2, 3]; // 这样赋值后,dataArray2 不再是响应式的,因为它已经被一个普通数组覆盖了

创建一个响应式对象(如 dataArray1),并在其中包含一个数组,直接给这个数组赋值时,该数组仍然是响应式的,因为它是响应式对象的一部分。

创建一个响应式数组(如 dataArray2),并直接给它赋值一个普通数组时,它将不再是响应式的,因为它已经被一个普通数组覆盖了。要保持响应式,需要在此数组基础上修改,而不是用一个新数组覆盖它。

失去响应式

let arr = reactive([])
 
function change(){
   let newArr = [1,2,3]
   arr = newArr
}

保持响应式

// 方法一:使用 ref
let arr = ref([])
 
function change(){
   let newArr = [1,2,3]
   arr.value = newArr
}
 
// 方法二:使用push 方法
let arr = reactive([])
 
function change(){
   let newArr = [1,2,3]
   arr.push(...newArr)
}
 
// 方法三:外层嵌套一个对象
let arr = reactive({list:[]})
 
function change(){
   let newArr = [1,2,3]
   arr.list = newArr
}

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

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

相关文章

函函函函函函函函函函函数——two

&#x1f929;本文作者&#xff1a;大家好&#xff0c;我是paperjie&#xff0c;感谢你阅读本文&#xff0c;欢迎一建三连哦。 &#x1f970;内容专栏&#xff1a;这里是《C知识系统分享》专栏&#xff0c;笔者用重金(时间和精力)打造&#xff0c;基础知识一网打尽&#xff0c;…

【DevOps视频】笔记】1. DevOps的诞生

视频官网 目录 一、DevOps介绍 定义&#xff1a; 作用&#xff1a; 核心&#xff1a; 二、软件开发流程 三、流程图 一、DevOps介绍 定义&#xff1a; Development & Operations的缩写&#xff0c;也就是开发&运维DevOps 是一个不断提高效率并且持续不断工作…

(八)Geoprocessing地理处理框架——基本介绍

&#xff08;八&#xff09;Geoprocessing地理处理框架——基本介绍 目录 &#xff08;八&#xff09;Geoprocessing地理处理框架——基本介绍 1.基本概念2.集成ArcToolbox3.多种使用方式3.1对话框3.2Python窗口3.3模型构建器3.4脚本 4.应用基础4.1启动ArcToolbox4.2激活扩展工…

PostgreSQL中创建索引的消极影响

相信大家在使用数据库中&#xff0c;提高SQL查询速度最简单的办法就是添加相关索引&#xff0c;但是其实我们创建的索引并不一定能用上&#xff0c;有时候顺序扫描也并不见的就比离散的索引扫描差&#xff0c;任何事物我们要辩证的看待&#xff0c;今天我们说明一下创建索引的一…

AQS 抽象同步队列的简单理解

前置知识&#xff1a; 可重入锁又叫递归锁&#xff0c;同一个线程在外层方法获取锁的时候&#xff0c;在进入该线程内层方法会自动获取锁&#xff0c;不会因为之前已经获取过还没释放就阻塞 同一个线程可以多次获得同一把锁 每个锁对象都有一个锁计数器和一个指向持有该锁的…

Python爬虫-D车网近半年(六个月)汽车销量排行榜

前言 本文是该专栏的第46篇,后面会持续分享python爬虫干货知识,记得关注。 在本专栏前面,笔者有单独详细介绍过该平台当前月更新的最新汽车销量排行榜数据。感兴趣的同学,可往前翻阅查看(Python爬虫-某懂车平台之汽车销量排行榜)。 而本文,笔者将详细来介绍该平台近半年…

【git】git提交代码-使用简易指南

1、创建新仓库&#xff1a;git init 创建新文件夹&#xff0c;打开执行&#xff1a;git init &#xff0c;创建新的git仓库 2、检出仓库&#xff1a;git clone 执行该命令&#xff0c;以创建一个本地仓库的克隆版本&#xff1a;git clone /path/to/repository 如果是远端服务器…

一文解析Systrace 的原理、流程及定制

一、原理和基本流程 Systrace是android性能调试优化的常用工具&#xff0c;它可以收集进程的活动信息&#xff0c;如界面布局、UI渲染、binder通信等&#xff1b;也可以收集内核信息&#xff0c;如cpu调度、IO活动、中断等&#xff1b;这些信息会统一时间轴&#xff0c;在Chro…

【ROS仿真实战】Gazebo仿真平台介绍及安装方法(一)

文章目录 前言一、Gazebo简介二、Gazebo仿真平台的基本概念三、Gazebo仿真平台的安装方法四、总结 前言 Gazebo仿真平台是一个广泛应用于机器人研发、测试和教育等领域的开源软件。它可以模拟机器人的运动、感知和控制等行为&#xff0c;并提供了丰富的物理引擎、传感器模拟和…

PYQT5学习笔记05——QObject父子对象API以及案例

一、父子对象API 我们在这里简单演示一下父子对象API的具体用法以及代码实现&#xff0c;父子对象API有五个&#xff0c;分别是setParent、parent、children、findChild、findChildren&#xff0c;接下来对每一个API都具体演示一下。 1、setParent(parent)和parent() setParen…

国外导师对博士后申请简历的几点建议

正所谓“工欲善其事&#xff0c;必先利其器”&#xff0c;想要申请国外的博士后职位&#xff0c;就要准备好相应的申请文书材料。如果说Cover Letter是职位的窍门砖&#xff0c;那么申请者的简历就是争取职位的决定性筹码。 相信大家已经看过许多简历的模版了&#xff0c;但是…

c++自学笔记

本笔记为从菜鸟教程边学边记录的笔记---》C 教程 | 菜鸟教程 面向对象程序设计 封装&#xff08;Encapsulation&#xff09;&#xff1a;封装是将数据和方法组合在一起&#xff0c;对外部隐藏实现细节&#xff0c;只公开对外提供的接口。这样可以提高安全性、可靠性和灵活性。…

vsftpd.conf各参数含义

文章目录 初始vsftdp.conf翻译后需修改参数write_enableYES&#xff08;启用任何形式的FTP写入命令&#xff09;userlist_file/etc/vsftpd.user_list、userlist_enableYES、userlist_denyNOlocal_umask022&#xff08;放开权限&#xff09;chroot_local_userYES&#xff08;限定…

【容器文件系统】了解容器 overlay 文件系统和 /var/lib/docker/overlay2下目录的作用

转载自 浅析 Docker overlay2 文件结构 docker(5): 层 朱双印 目的 有这个问题困惑着我&#xff1a;容器删除 docker rm 后&#xff0c;docker cp 到容器内的文件&#xff0c;在 /var/lib/docker/overlay2 目录中是否还会存在 答案&#xff1a;容器删除后 docker rm 后&…

银河麒麟操作系统,安装Gitlab 基于docker

不废话。直接上干货 操作系统信息 ############## Kylin Linux Version ################# Release: Kylin Linux Advanced Server release V10 (Sword) Kernel: 4.19.90-24.4.v2101.ky10.aarch64 Build: Kylin Linux Advanced Server release V10 (SP2) /(Sword)-aarch64-…

【电商必学】 WhatsApp 全新攻略:什么是交互式消息模板

网购与WhatsApp等社交通讯平台有着密不可分的关系&#xff0c;为什么这么说呢&#xff1f;因为基本上所有的网购的平台都会提供查询、下单方式给客户&#xff0c;而WhatsApp是全世界使用率最高的通讯平台&#xff0c;所以大部分电子商户都会选择WhatsApp Business与电子商务连接…

「C/C++」C/C++静态链接库与动态链接库

博客主页&#xff1a;何曾参静谧的博客 文章专栏&#xff1a;「C/C」C/C学习 目录 相关术语案例环境&#xff1a;Win10VS2019一、链接库介绍二、静态链接库&#xff08;Static Library&#xff09;2.1、静态库优缺点2.2、静态库的创建2.2.1、创建静态库项目2.2.2、添加.h头文件…

实战案例分享 | 临近假期,项目突发各种问题…

五一的调休补班一下子把三个星期的作息成功打乱&#xff0c;大家在吐槽的同时也不忘给自己延长假期&#xff0c;平时加班攒下的假期都充分利用上了。但办公室的项目经理小李这两天总长吁短叹&#xff0c;感觉假期也要随时随地办公。一问才知原来是临近假期时&#xff0c;项目突…

ARL灯塔(无需VPS版)

标题随便写&#xff0c;能看到都是有缘人 搭建灯塔那么繁琐的步骤&#xff0c;远不如爆破一个灯塔是吧(狗头) 而且还可能买不起VPS的情况(例如我) 那不如写一个脚本去爆破灯塔的弱口令 整治网络安全 从你我做起 fofa语法&#xff1a; icon_hash"1708240621"…

零售新时代,零售行业数字化破局的新路径

深夜11点&#xff0c;门店店长小张还在加班&#xff0c;因为小张还需要盘点今日销售额、库存等信息&#xff0c;这些整理好的数据需要手动录入至总公司的系统中。 多门店的零售行业中&#xff0c;这是他们每天的工作日常&#xff1a;门店先通过excel做手工报表&#xff0c;再把…