zoukankan      html  css  js  c++  java
  • JS四种判断数据类型的方法:typeof、instanceof、constructor、Object.prototype.toString.call()

    1.typeof

    1 console.log(typeof "");  //string
    2 console.log(typeof 1);  //number
    3 console.log(typeof true);  //boolean
    4 console.log(typeof null);  //object
    5 console.log(typeof undefined);  //undefined
    6 console.log(typeof []);  //object
    7 console.log(typeof function(){});  //function
    8 console.log(typeof {});  //object

    控制台输出结果:

    typeof对于基本数据类型判断是没有问题的,但是遇到引用数据类型(如:Array)是不起作用的。

    2.instanceof

    1 console.log("1" instanceof String);
    2 console.log(1 instanceof Number);
    3 console.log(true instanceof Boolean);
    4 //            console.log(null instanceof Null);
    5 //            console.log(undefined instanceof Undefined);
    6 console.log([] instanceof Array);
    7 console.log(function(){} instanceof Function);
    8 console.log({} instanceof Object);

    暂且不考虑null和undefined(这两个比较特殊),控制台输出结果:

    可以看到前三个都是以对象字面量创建的基本数据类型,但是却不是所属类的实例,这个就有点怪了。后面三个是引用数据类型,可以得到正确的结果。如果我们通过new关键字去创建基本数据类型,你会发现,这时就会输出true,如下:

    接下再来说说为什么null和undefined为什么比较特殊,实际上按理来说,null的所属类就是Null,undefined就是Undefined,但事实并非如此:控制台输出如下结果:

    浏览器压根不认识这两货,直接报错。在第一个例子你可能已经发现了,typeof null的结果是object,typeof undefined的结果是undefined

    尤其是null,其实这是js设计的一个败笔,早期准备更改null的类型为null,由于当时已经有大量网站使用了null,如果更改,将导致很多网站的逻辑出现漏洞问题,就没有更改过来,于是一直遗留到现在。作为学习者,我们只需要记住就好。

    3.constructor

    1 console.log(("1").constructor === String);
    2 console.log((1).constructor === Number);
    3 console.log((true).constructor === Boolean);
    4 //console.log((null).constructor === Null);
    5 //console.log((undefined).constructor === Undefined);
    6 console.log(([]).constructor === Array);
    7 console.log((function() {}).constructor === Function);
    8 console.log(({}).constructor === Object);

    (这里依然抛开null和undefined)乍一看,constructor似乎完全可以应对基本数据类型和引用数据类型,都能检测出数据类型,事实上并不是如此,来看看为什么:

    1 function Fn(){};
    2 
    3 Fn.prototype=new Array();
    4 
    5 var f=new Fn();
    6 
    7 console.log(f.constructor===Fn);
    8 console.log(f.constructor===Array);

    我声明了一个构造函数,并且把他的原型指向了Array的原型,所以这种情况下,constructor也显得力不从心了。

    看到这里,是不是觉得绝望了。没关系,终极解决办法就是第四种办法,看过jQuery源码的人都知道,jQuery实际上就是采用这个方法进行数据类型检测的。

    4.Object.prototype.toString.call()

     1 var a = Object.prototype.toString;
     2 
     3 console.log(a.call("aaa"));
     4 console.log(a.call(1));
     5 console.log(a.call(true));
     6 console.log(a.call(null));
     7 console.log(a.call(undefined));
     8 console.log(a.call([]));
     9 console.log(a.call(function() {}));
    10 console.log(a.call({}));

    参考博客:https://www.cnblogs.com/xuniannian/p/7452086.html

    参考博客:https://www.cnblogs.com/zt123123/p/7623409.html

    今天你学习了吗!!!
  • 相关阅读:
    ASP.NET动态加载用户控件的页面生成过程
    简单的flash与asp.net通信(LoadVars类)
    转 推荐两本FLASH RIA应用开发方面的书籍
    关于代码加密解密保护
    转 利用 SharpZipLib方便地压缩和解压缩文件
    在C#中应用哈希表(Hashtable)
    C#中解析并运行一个本地命令行
    About Windows Live Writer
    安装sql server 2008,提示要删除SQL Server 2005 Express 工具,可我根本没装
    [转] C#中的null
  • 原文地址:https://www.cnblogs.com/nayek/p/11671747.html
Copyright © 2011-2022 走看看