js数据类型检测的方法

数据类型检测的方法有哪些?

1、typeof

    console.log(typeof 2); // number
    console.log(typeof true); // boolean
    console.log(typeof 'str'); // string
    console.log(typeof []); // object
    console.log(typeof function(){}); // function
    console.log(typeof {}); // object
    console.log(typeof undefined); // undefined
    console.log(typeof null); // object

typeo:f 其中数组、对象、null 都会被判断为 object,其他判断都正确。

2、instanceof

  • instanceof 可以正确判断对象的类型,其内部运行机制是判断在其原型链中能否找到该类型的原型。
    console.log(2 instanceof Number); // false
    console.log(true instanceof Boolena); // false
    console.log('str' instanceof String); // false

    console.log([] instanceof Array); // trur
    console.log(function(){} instanceof Function); // true
    console.log({} instanceof Object); // true

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

3、constructor

    console.log((2).constructor === Number); // true
    console.log((true).constructor === Boolean); // true
    console.log(('str').constructor === String); // true
    console.log(([]).constructor === Array); // true
    console.log((function(){}).constructor === Function); // true
    console.log(({}).constructor === Object); // true

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

    function Fn() {};

    Fn.prototype = new Array();

    let f = new Fn();

    console.log(f.constructor === Fn); // false
    console.log(f.constructor === Array); // true

4、Object.prototype.toString.call()

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

    console.log(a.call(2)); // [object Number]
    console.log(a.call(true)); // [object Boolean]
    console.log(a.call('str')); // [object String]
    console.log(a.call([])); // [object Array]
    console.log(a.call(function(){})); // [object Function]
    console.log(a.call({})); // [object Object]
    console.log(a.call(undefined)); // [object Undefined]
    console.log(a.call(null)); // [object Null]
  • 同样是检测对象 obj 调用 toString 方法,obj.toString() 的结果和 Object.prototype,toString.call(obj) 的结果不一样,这是为什么?
    • 这是因为 toString 是 Object 的原型方法,而 Array、function 等类型操作为 Object 的实例,都重写了 toString 方法。不同的对象类型调用 toSting 方法时,根据原型链的知识,调用的是对应的重写之后的 toString 方法(function 类型返回内容为函数体的字符串,Array类型返回元素组成的字符串),而不会去调用 Object 上原型 toString(返回对象的具体类型),所以采用 object.toString() 不能得到其对象类型,只能将 obj 转换为字符串类型;因此,在想要得到对象的具体类型时,应该调用 Object 原型上的 toString 方法。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值