码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • JavaScript中的 inludes 和 indexOf 方法 | 判断字符串或数组中是否存在对应的元素| 相同点与不同点 | 代码详解


    目录

    • JavaScript中的inludes和indexOf方法
      • 1.数组中的includes和indexOf方法比较
        • 1.1 函数返回值的不同
        • 1.2 函数第二个参数——开始查找的位置
        • 1.3 includes 和 indexOf 方法的区别
      • 2 .字符串和数组中的 indexOf | includes 方法比较
      • 3. 小结
      • 参考

    JavaScript中的inludes和indexOf方法

    • 主要用途:用于判断字符串或者数组中是否存在对应的元素

    1.数组中的includes和indexOf方法比较

    1.1 函数返回值的不同

    • includes方法返回的是Boolean类型的值。元素存在返回true,不存在返回false。
    • indexOf方法返回的是Number类型的值。元素存在则返回第一次出现的索引值,不存在则返回-1。
    • 所以当作为if的判断条件时(如下代码示例),
      • 对于includes方法的返回值result1,使用if(result1){...}进行判断元素是否存在;
      • 对于indexOf方法的返回值result2,使用if(result2 !== -1){...}或者if(result2 >= 0){...}判断元素是否存在。
    • 代码示例:
    let arr1 = [1,2,3,4]
    let result1 = arr1.includes(2) 
    let result2 = arr1.indexOf(2)
    console.log(result1) //true Boolean类型
    console.log(result2) //1 Number类型
    
    • 1
    • 2
    • 3
    • 4
    • 5

    image-20221110234538884

    1.2 函数第二个参数——开始查找的位置

    • indexOf和includes都可以添加第二个参数,表示开始查找的位置:
      • 当为正数时如indexOf(2,2)表示从索引值为2的元素开始从左往右查找是否有元素2
      • 为负数时如indexOf(2,-2)表示从从后往前的第2个数字开始从左往右查找是否有元素2(注意查找顺序都是从左往右),如数组[1,2,3,4,5,6].indexOf(2,-2)表示从5的位置从左往右查找是否有2。
      • includes方法的第二个参数也是一样的。
    • 代码示例:
    let arr1 = [1,2,3,4]
    console.log(arr1.indexOf(2,2)) //-1
    console.log(arr1.includes(2,2)) //false
    console.log(arr1.indexOf(3,-2))//2
    console.log(arr1.includes(3,-2))//true
    
    • 1
    • 2
    • 3
    • 4
    • 5

    image-20221110234553410

    1.3 includes 和 indexOf 方法的区别

    • includes能匹配到NaN,但是indexOf不行;
    • includes能识别到稀疏数组中的undefined,但是indexOf不可以.
    • 代码示例:
    console.log([NaN,1,2,3].includes(NaN))//true
    console.log([NaN,1,2,3].indexOf(NaN))//-1
    //定义一个稀疏数组arr,只给索引值为3的元素赋值1,则其他为undefined
    let arr = []
    arr[3] = 1
    console.log(arr) //[empty × 3, 1]
    console.log(arr.includes(undefined)) //true
    console.log(arr.indexOf(undefined))  //-1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    image-20221110235740392

    2 .字符串和数组中的 indexOf | includes 方法比较

    • 区别:
      • 字符串中的indexOf和includes方法会对匹配的元素进行数据类型转换;
      • 数组中的indexOf和includes方法是进行严格匹配===,即当元素的数据类型不相同时,无法匹配到对应的元素。
    • 代码示例:
    //数组的情况:严格匹配
    console.log(['1','2','3','4'].includes(2))//false
    console.log(['1','2','3','4'].indexOf(2))//-1
    //字符串的情况:会做类型转换
    console.log('12345'.includes(2))//true
    console.log('12345'.indexOf(2))//1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    image-20221111000128298

    3. 小结

    以上便是JavaScript中的inludes和indexOf方法的一些内容,有任何不足欢迎在评论区补充。

    参考

    参考视频教程 【JS每日一题:JS中的includes和indexOf方法,到底有什么区别?】

  • 相关阅读:
    Observability:使用 OpenTelemetry 手动检测 .NET 应用程序
    计算机视觉 | 基于图像处理和边缘检测算法的黄豆计数实验
    如何通过bat批处理实现快速生成文件目录,一键生成文件名和文件夹名目录
    Python【多分支练习】
    如何做接口测试呢?接口测试有哪些工具
    Xgboost报错 ValueError: Invalid shape: (1650, 2) for label
    架构安全性设计、部分示例及原理分析
    云开发中的战斗机 Laf,让你像写博客一样写代码
    使用 elasticdump 跨版本迁移 ES 数据
    Windows 下 bat 脚本调用 Git bash 环境 sh 脚本
  • 原文地址:https://blog.csdn.net/dxy1128/article/details/127798703
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号