• indexOf、instanceOf、typeOf、valueOf详解


    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.prototype console.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);//true
    6 console.log(Dave instanceof Person);//true
    复制代码
    
    

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

    3、typeof

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

    复制代码
    1 console.log(typeof("Json"));//string
    2 console.log(typeof(2));//number
    3 console.log(typeof(true));//boolean
    4 console.log(typeof({a:1}));//object
    5 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);//true
    4 console.log(a===b);//false

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

    特殊的还有

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

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

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

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

    1 console.log(null==0);//false
    2 console.log(undefined==0);//false
  • 相关阅读:
    什么是“开放构造类型”,“封闭构造类型”
    代码整洁整洁之道读书笔记 2
    学习 WCF By Visual Studio 2010 (1)起步“全双工”
    代码整洁整洁之道读书笔记 1
    学习 WCF By Visual Studio 2010 (2) 宿主
    持久层通用组件设计与范例,写给某孩子(基于JDBC)
    [zz]JS后退一页, JS返回上一页代码, JS返回下一页,JS返回第几页,JS页面跳转, JS引用JS
    web下vs2008+crystal report 不预览直接打印
    用SQL语句删除重复记录
    Gridview 添加行.
  • 原文地址:https://www.cnblogs.com/zhengxingpeng/p/6682565.html
Copyright © 2020-2023  润新知