博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
indexOf、instanceOf、typeOf、valueOf详解
阅读量:4320 次
发布时间:2019-06-06

本文共 2378 字,大约阅读时间需要 7 分钟。

1、indexOf()

该方法用来返回某个指定的字符串值在字符串中首次出现的位置。

语法:indexOf(searchvalue,fromindex);两个参数,参数一表示查询的字符串值,参数二可选表示开始查询的起始位置,若不写默认从首字符开始查询

1 var string = "abcdeADhu390u09";2 console.log(string.indexOf("d"));//3  注意下标值从0开始3 console.log(string.indexOf("D"));//6

上面代码都只有一个参数分别打印出"d"、"D"字符串值首次出现的位置,发现输出的值不同,说明indexOf()方法对大小写有区分。

下面这段代码传入两个参数,根据前面说的参数二表示查询的起始位置,所以从第五位开始查询"d"首次出现的位置,查询不到返回-1

console.log(string.indexOf("d",4));//-1

indexOf()方法还常用来判断浏览器的类型,其用法如下:

1 if(navigator.userAgent.indexOf("Firefox")>0){2     return "Firefox";3 }else if(navigator.userAgent.indexOf("Chrome")>0){4     return "Chrome";5 }else if(navigator.userAgent.indexOf("Opera")>0){6     return "Opera";7 }
以navigator.userAgent.indexOf("Opera")查询来讲,若打开的浏览器是欧朋则返回一个大于0的值,否则返回-1 2、instanceOf 该运算符用来检测对象的类型 语法:object instanceof constructor   参数object表示要检测的对象,参数constructor表示某个构造函数
function Person(){
}var Dave = new Person(); //Object.prototypeOf(Dave)===Person.prototypeconsole.log(Dave instanceof Person);//true
 
可以这样理解:instanceof检测constructor.prototype是否存在于参数object原型链上。若存在返回true 上面说的是较常规的用法,现在来看看在继承中的用法
1 function Person(){};2 function Student(){};3 Student.prototype = new Person();//js中的原型继承4 var Dave = new Student();5 console.log(Dave instanceof Student);//true6 console.log(Dave instanceof Person);//true
 

上面一段代码判断Dave是否是Student的实例,并且是否是其父类型的实例

3、typeof

该运算符用来检测基本数据类型

1 console.log(typeof("Json"));//string2 console.log(typeof(2));//number3 console.log(typeof(true));//boolean4 console.log(typeof({a:1}));//object5 console.log(typeof(function(){}));//function 6 console.log(typeof(undefined));//undefined

在ES6之前typeof返回值就是上面列出的六种:string、number、bollean、object、function、undefined;ES6出来后又增加了一种symbol

console.log(typeof(Symbol()));//symbol

4、valueOf()

该方法返回Boolean对象的原始值

语法:booleanObject.valueOf()

1 var boo = new Boolean(true);2 console.log(boo.valueOf());

补充下与本章不相关的小知识点:

这里穿插一点"=="与"==="的小知识点

1 var a = undefined;2 var b = null;3 console.log(a==b);//true4 console.log(a===b);//false

null与undefined在"=="情况下返回true,因为他们是类似的值,在"==="情况下返回false,因为他们不是相同类型的值。

特殊的还有

1 console.log(NaN==NaN);//false2 console.log(3==NaN);//false

若有一个操作符是NaN,在"=="情况下返回false,即使两个操作数都是NaN,在"=="情况下也返回false

1 console.log(false==0);//true2 console.log(true==1);//true3 console.log(true==2);//false

在操作符为"=="时,true与1返回true

1 console.log(null==0);//false2 console.log(undefined==0);//false

 

 

 

转载于:https://www.cnblogs.com/daicunya/p/6145252.html

你可能感兴趣的文章
警惕!年轻人要拥抱自动化和人工智能作为通信的未来
查看>>
Python给数字前固定位数加零
查看>>
python 多进程和多线程对比
查看>>
【转载】 wpf无边框的方法以及拖拽的问题
查看>>
Web自动化测试 二 ----- HTML
查看>>
sql 入门经典(第五版) Ryan Stephens 学习笔记  第四部分:建立复杂的数据库查询/...
查看>>
[原创]Keys的基本操作总结,判断Keys中是否存在Keys.Control|Keys.Alt,移除Keys中的部分键值。...
查看>>
主题样式之背景图片不随鼠标滑动而移动
查看>>
Centos 中文乱码
查看>>
IDLE常用快捷键
查看>>
MyBatis课程4
查看>>
Git使用笔记
查看>>
Java概述
查看>>
Python数据分析与展示第0&1周学习笔记(北理工 嵩天)
查看>>
log4cplus使用
查看>>
[git]rebase和merge
查看>>
java动态代理
查看>>
Selector的2种样式
查看>>
Mac 卸载mysql
查看>>
php-fpm用socket连接
查看>>