美文网首页
JavaScript如何数据类型判断

JavaScript如何数据类型判断

作者: 快乐猿Days | 来源:发表于2023-11-17 13:58 被阅读0次

    众所周知JavaScript是一个弱类型、动态语言,定义变量时无需指定,在运行时会自动判断类型。但我们实际开发中经常有类型判断的场景。那么JavaScript有哪些常用的类型判断方法呢?答案是有如下几种:typeof、instanceof、constructor、Object.prototype.toString.call()。

    1、typeof
    typeof是一个运算符,用于返回一个表示操作数类型的字符串。它可以用于确定一个变量的类型,或者一个表达式的类型。


    image.png

    需要注意的是,typeof运算符返回的是一个字符串,而不是一个类型。此外,对于数组、对象、null ,typeof运算符返回的都是"object",无法精确区分具体的类型。

    2、instanceof
    instanceof 可以正确判断对象的类型,其内部运行机制是判断在其原型链中能否找到该类型的原型。


    image.png

    从上图可以看到,instanceof 只能正确判断引用数据类型,而不能判断基
    本数据类型。instanceof 运算符可以用来测试一个对象在其原型链
    中是否存在一个构造函数的 prototype 属性。

    3、constructor


    image.png

    constructor 有两个作用,一是判断数据的类型,二是对象实例通过constrcutor 对象访问它的构造函数。需要注意,如果创建一个对象来改变它的原型,constructor 就不能用来判断数据类型了:


    image.png

    4、Object.prototype.toString.call

    Object.prototype.toString.call() 使用 Object 对象的原型方法
    toString 来判断数据类型:


    image.png

    同样是检测对象 obj 调用 toString 方法,obj.toString()的结果和
    Object.prototype.toString.call(obj)的结果不一样,这是为什
    么?
    这是因为 toString 是 Object 的原型方法,而 Array、function 等类
    型作为 Object 的实例,都重写了 toString 方法。不同的对象类型调
    用 toString 方法时,根据原型链的知识,调用的是对应的重写之后
    的 toString 方法(function 类型返回内容为函数体的字符串,Array
    类型返回元素组成的字符串…),而不会去调用 Object 上原型
    toString 方法(返回对象的具体类型),所以采用 obj.toString()
    不能得到其对象类型,只能将 obj 转换为字符串类型;因此,在想要
    得到对象的具体类型时,应该调用 Object 原型上的 toString 方法。

    以上就是对JavaScript数据类型判断的整理,大家在实际使用中,根据具体情况选用吧。

    相关文章

      网友评论

          本文标题:JavaScript如何数据类型判断

          本文链接:https://www.haomeiwen.com/subject/txaywdtx.html