indexOf、instanceOf、typeOf、valueOf详解

1、indexOf()

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

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

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

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

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

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

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

if(navigator.userAgent.indexOf("Firefox")>0)
{     
    return "Firefox";  
}else if(navigator.userAgent.indexOf("Chrome")>0)
{
    return "Chrome"; 
}else if(navigator.userAgent.indexOf("Opera")>0){ 
    return "Opera"; 
}

以navigator.userAgent.indexOf("Opera")查询来讲,若打开的浏览器是欧朋则返回一个大于0的值,否则返回-1

2、instanceOf
该运算符用来检测对象的类型
语法:object instanceof constructor
参数object表示要检测的对象,参数constructor表示某个构造函数

function Person(){} 
var Dave = new Person();  
//Object.prototypeOf(Dave)===Person.prototype
console.log(Dave instanceof Person);//true

可以这样理解:
instanceof检测constructor.prototype是否存在于参数object原型链上。
若存在返回true
上面说的是较常规的用法,现在来看看在继承中的用法

function Person(){}; 
function Student(){}; 
Student.prototype = new Person();//js中的原型继承
var Dave = new Student();
console.log(Dave instanceof Student);//true
console.log(Dave instanceof Person);//true

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

3、typeof

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

console.log(typeof("Json"));//string
console.log(typeof(2));//number
console.log(typeof(true));//boolean
console.log(typeof({a:1}));//object
console.log(typeof(function(){}));//function  
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()

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

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

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

var a = undefined; 
var b = null; 
console.log(a==b);//true
console.log(a===b);//false

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

特殊的还有

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

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

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

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

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

声明:该文章系转载,转载该文章的目的在于更广泛的传递信息,并不代表本网站赞同其观点,文章内容仅供参考。

本站是一个个人学习和交流平台,网站上部分文章为网站管理员和网友从相关媒体转载而来,并不用于任何商业目的,内容为作者个人观点, 并不代表本网站赞同其观点和对其真实性负责。

我们已经尽可能的对作者和来源进行了通告,但是可能由于能力有限或疏忽,导致作者和来源有误,亦可能您并不期望您的作品在我们的网站上发布。我们为这些问题向您致歉,如果您在我站上发现此类问题,请及时联系我们,我们将根据您的要求,立即更正或者删除有关内容。本站拥有对此声明的最终解释权。