JavaScript数组中的indexOf方法
最近项目遇到一个小问题代码我会简化成小例子展示给大家。
用心看到最后会有收获哈,基础扎实的童鞋可以直接跳到数组类型使用。
说到 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); // 其中:
相关文章
- JavaScript小游戏实例:简单的键盘练习
- jQuery 追加元素、拼接元素的方法总结(append、html、insertBefore、before等) 初识document.onkeydown及其兼容性问题 js学习笔记27----键盘事件 JavaScript onkeydown事件入门实例(键盘某个按键被按下)
- ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 用javascript在客户端删除某一个cookie键值对 input点击链接另一个页面,各种操作。 C# 往线程里传参数的方法总结 TCP/IP 协议 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图 (转)值得学习百度开源70+项目
- Javascript将字符串日期格式化为yyyy-mm-dd的方法 js number 类型 没有length 属性 string类型才有
- 你不知道的JavaScript--Item33 跨域总结与解决的方法
- js 从数据数组中返回选定的数据元素 JavaScript slice() 方法
- 【学习笔记21】JavaScript数组的基本方法
- 【学习笔记23】JavaScript数组的遍历方法
- 【学习笔记24】JavaScript数组遍历方法习题
- JavaScript数组及相关方法
- 前端基础 - JavaScript方法覆盖
- 2022 JavaScript 数组(Array)方法1w+字汇总(含数组新特性,全到没朋友,再也不用东拼西凑了)
- JavaScript关闭窗口的同时打开新页面的方法
- JavaScript中unicode编码与String互转(三种方法)
- 原生JavaScript进阶训练---重写map方法
- JavaScript中十种一步拷贝数组的方法
- JavaScript 数组遍历方法的对比
- javascript js date ios手机浏览器出现 NAN的问题解决方法
- 前端三剑客:html、css、javascript
- Javascript使用function创建类的两种方法
- JavaScript HTML DOM replaceChild替换子节点
- 原生js源码之JavaScript的call方法,自己来实现
- JavaScript Array数组sort方法的使用
- JavaScript引用类型之Array数组的栈方法与队列方法
- javascript通过改变滚动条滚动来显示某些元素的scrollIntoView()方法
- HTML 一种重定向方法 / JavaScript 两种重定向方法