zl程序教程

您现在的位置是:首页 >  前端

当前栏目

JavaScript数组中的indexOf方法

2023-09-27 14:21:44 时间


最近项目遇到一个小问题代码我会简化成小例子展示给大家。

用心看到最后会有收获哈,基础扎实的童鞋可以直接跳到数组类型使用。

说到 indexOf 大家并不陌生,判断字符串是否包涵子字符串时特别常用(正则不熟练同学的利器)。

String 类型的使用

温习一下大家熟知的字符串用法,举个例子


let str = orange;  str.indexOf(o);  //0  str.indexOf(n);  //3  str.indexOf(c);  //-1  

这里 0 和 3 分别是 o 和 n 在字符串中出现的位置。起始下标是 0。而 -1 代表未匹配。

曾经有人问我为什么偏偏是 -1 不是 null 或者 undefined。你去问制定规则的人啊!一脸无奈。

大家看到这里感觉没什么亮点啊,别急接着再来一个例子


let numStr = 2016;  numStr.indexOf(2);  //0  numStr.indexOf(2);  //0  

看到这里有个小点就是 indexOf 会做简单的类型转换,把数字转换成字符串 2 然后再执行。

Number 类型的使用

大家可能会想 number 类型有没有 indexOf 方法因为会做隐式转换嘛!明确告诉大家没有,上例子


let num = 2016;  num.indexOf(2);  //Uncaught TypeError: num.indexOf is not a function  

非要对 number 类型使用 indexOf 方法嘞?那就转换成字符串咯,接着上例来写


//二逼青年的写法  num = 2016;  num.indexOf(2);  //0  //普通青年的写法  num.toString().indexOf(2);  //0  //文艺青年的写法  ( + num).indexOf(2);  //0  

第一种写法简单直接,对于已知的较短的数字也不是不可行。但是 num 变量针对不同数据是变化的时候,怎么办呢?

第二种写法最为常用,但对比第三种写法长了一点。哈哈,其实都可以,代码洁癖的人喜欢第三种

Array 类型的使用

大家提起精神,大boss来了。

数组方法大家再熟悉不过了,却忽略了数组有 indexOf 这个方法(我个人感觉)。

干说不练瞎扯淡,遇到了什么问题,注意点又在哪里?


let arr = [orange, 2016, 2016];  arr.indexOf(orange); //0  arr.indexOf(o); //-1  arr.indexOf(2016); //1  arr.indexOf(2016); //-1  

这里没把例子拆的那么细,四个用例足以说明问题。

arr.indexOf(orange) 输出 0 因为 orange 是数组的第 0 个元素,匹配到并返回下标。 arr.indexOf(o) 输出 -1 因为此方法不会在每一个元素的基础上再次执行 indexOf 匹配。 arr.indexOf(2016) 输出 1 因为此方法从头匹配直到匹配到时返回第一个数组元素的下表,而不是返回全部匹配的下标。 arr.indexOf(2016) 输出 -1 注意:这里不会做隐式类型转换。

既然坑已经发现我们不妨刨根问底。去MDN官网一看究竟。对此话题感兴趣的朋友可以直接跳转到 Array.prototype.indexOf()

只想了解的朋友下面给大家官方的 Description。

indexOf() compares searchElement to elements of the Array using strict equality (the same method used by the === or triple-equals operator).

一目了然,这里用的是严格等于(===)。大家做类似判断的时候多留意。不要误认为数字会转成字符串,同理字符串也不会转换成数字。

总结


小知识点积累,不作为深入讨论的话题,因此这里没有解释 indexOf() 的第二个参数,相信大家都知道第二个参数的作用,不知道的可以看这里String.prototype.indexOf(),然后结合上面数组的链接也看一下第二个参数。


作者:orangexc

来源:51CTO


JavaScript中Date对象的方法解析 JavaScript中Date对象的方法解析 上篇文章讲到了JavaScript的Date对象,对Date对象的创建和属性进行了讲解,这篇博客我们来讲一讲Date对象的方法有哪些。 1.获取日期的方法 // 获取当前的日期 var oDate=new Date(); // 方法 描述 // getDate() 从 Date 对象返回一个月中的某一天 (1 ~ 31)。 console.log(oDate.getDate()); // getDay() 从 Date 对象返回一周中的某一天 (0 ~ 6)。
JavaScript的字符串之HTML包装方法 JavaScript的字符串之HTML包装方法 前面以前文章我们讲解了字符串的各种方法。这篇文章对字符串的方法进行一些补充。 1.字符串的indexOf()和lastIndexOf()方法的补充 var str= hello world // indexOf() lastIndexOf() // 不加第二个参数 console.log(str.indexOf( l // 2 console.log(str.lastIndexOf( l // 9 console.log(str.indexOf( l ,5));// 9 5之后
JavaScript数组对象的迭代方法详解 JavaScript数组对象的迭代方法详解 上一篇博客讲到了数组的方法,当然里边比较复杂的就是数组的迭代方法,因为涉及到了回调函数,所以这篇博客我们来详细讲解一下js数组迭代方法的使用。 1.forEach(funcrion(value,index,arr){}):对数组的每一项运行给定函数,这个方法不进行返回,所以一般用于让数组循环执行某方法。 var arr=[1,2,3,4,5,6]; arr.forEach(function(val,index,arr){ console.log(val,index,arr); // 其中: