news 2026/4/16 13:46:17

this.selectedTestType.findIndex(x => x.name === item.name);findIndex 的作用详细介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
this.selectedTestType.findIndex(x => x.name === item.name);findIndex 的作用详细介绍

// 选中 / 取消toggleTestType(item:TestTypeItem){item.checked=!item.checked;constindex=this.selectedTestType.findIndex(x=>x.name===item.name);if(item.checked&&index===-1){this.selectedTestType.push(item);}elseif(!item.checked&&index>-1){this.selectedTestType.splice(index,1);}}

1. findIndex 的作用

  • const index = this.selectedTestType.findIndex(x => x.name === item.name);

  • findIndex 会遍历数组,找出 第一个满足条件的元素的索引。

  • 返回值:

    • 如果找到匹配元素 → 返回该元素在数组中的索引(从 0 开始)。

    • 如果没有找到 → 返回 -1。

举个例子:

constarr=['a','b','c'];arr.findIndex(x=>x==='b');// 返回 1arr.findIndex(x=>x==='d');// 返回 -1

所以 -1 就是 数组中不存在这个元素的标记。

2. 为什么写 index === -1 和 index > -1

if(item.checked&&index===-1){this.selectedTestType.push(item);}elseif(!item.checked&&index>-1){this.selectedTestType.splice(index,1);}
  • item.checked && index === -1:

    • 条件解释:当前项被选中,但还没有在已选数组里

    • 动作:把它加入 selectedTestType。

  • !item.checked && index > -1:

    • 条件解释:当前项被取消选中,并且在已选数组里存在

    • 动作:从 selectedTestType 中移除它。

  • 关键点:

    • -1 表示“未找到”,所以要用它判断是否存在。

    • index > -1 表示“找到了”,可以安全地删除。

详细解释:array.splice(start, deleteCount, …items)

  • start → 从数组的哪个索引位置开始操作

  • deleteCount → 要删除多少个元素

  • …items → 可选,要插入的新元素

this.selectedTestType.splice(index,1);

index → 找到的要删除的元素在数组中的位置

1 → 只删除一个元素

没有提供其他元素 → 所以只是删除,不添加新元素

这一行就是 从 selectedTestType 数组中移除被取消选中的测试类型。

3. 总结

  • index 的确是从 0 开始计数的,但 findIndex 没有找到时才返回 -1。

  • 所以这里的判断逻辑是为了:

  • 防止重复添加(避免数组中出现重复元素)

  • 只删除存在的元素,避免报错

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:56:59

39、超越传统界限:高频跟踪与金融套期保值技术揭秘

超越传统界限:高频跟踪与金融套期保值技术揭秘 1. 高频跟踪问题提出 在信号处理和控制领域,传统跟踪方法存在物理限制,难以有效应对一些干扰。然而,通过采用合适的模拟模型和多速率技术,有望在低采样率下实现(次)最优跟踪与干扰抑制,这为数字控制系统带来了新的范例。…

作者头像 李华
网站建设 2026/4/16 11:55:49

十字路口的抉择:B端与C端C++开发者的职业路径全解析

在C开发者的职业道路上,一个经典的选择题横亘在前:是深入服务企业与系统的B端(Business) 领域,还是投身于创造直接用户价值的C端(Consumer) 世界?这不仅是一个技术栈的选择&#xff…

作者头像 李华
网站建设 2026/4/16 11:56:15

8、脚本编程中的替代语法与循环结构

脚本编程中的替代语法与循环结构 1. 正则表达式脚本 在脚本编写中,使用正则表达式进行条件测试是一项很实用的技能。例如,我们可以处理美式英语和英式英语中“color”的不同拼写,即“color”和“colour”。以下是实现该功能的脚本代码: if [[ $REPLY =~ colou?r ]] ; …

作者头像 李华
网站建设 2026/4/16 13:34:04

11、流编辑器(sed)与 Apache 虚拟主机自动化

流编辑器(sed)与 Apache 虚拟主机自动化 1. 流编辑器(sed)基础操作 1.1 执行脚本与文件格式化 在命令行中,我们可以使用以下命令执行脚本并处理当前目录下的 UPPMT 目录文件: $ parsecsv.sh tools通过这个命令,我们能以更易读的方式格式化文件,让普通文本文件不…

作者头像 李华