一、indexOf()浏览器
该方法用来返回某个指定的字符串值在字符串中首次出现的位置。函数
语法:indexOf(searchvalue,fromindex);两个参数,参数一表示查询的字符串值,参数二可选表示开始查询的起始位置,若不写默认从首字符开始查询prototype
var string = "abcdeADhu390u09"; console.log(string.indexOf("d"));//3 注意下标值从0开始 console.log(string.indexOf("D"));//6
上面代码都只有一个参数分别打印出"d"、"D"字符串值首次出现的位置,发现输出的值不一样,说明indexOf()方法对大小写有区分。code
下面这段代码传入两个参数,根据前面说的参数二表示查询的起始位置,因此从第五位开始查询"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 原型链
二、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的实例,而且是不是其父类型的实例string
三、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
四、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