zoukankan      html  css  js  c++  java
  • typeof、instanceof与constructor

    typeof返回一个表达式的数据类型的字符串,返回结果为js基本的数据类型,包括number,boolean,string,object,undefined,function.

    语法: typeof(data) 或 typeof data

    instanceof则为判断一个对象是否为某一数据类型,或一个变量是否为一个对象的实例;返回boolean类型.
    语法: o instanceof A

    以下为综合实例:

     console.log("typeof(1):" + typeof(1));//number
     console.log("typeof("abc"):" + typeof("abc"));//string
     console.log("typeof(true):" +typeof(true));//boolean
     console.log("typeof(2009-2-4):" + typeof(2009-2-4));//number
     console.log("typeof("2009-2-4"):" + typeof("2009-2-4"));//string
     console.log("typeof(m):" + typeof(m));//undefined
    
     var d=new Date();
     console.log("typeof(d):" + typeof(d));//object
    
     function Person(){};
     console.log("typeof(Person):" + typeof(Person));//function
    
     var a=new Array();
     console.log("typeof(a):" + typeof(a));//object
     console.log("a instanceof Array:" + (a instanceof Array)); //true
    
     var h=new Person();
     var o={};
     console.log("h instanceof Person:" + (h instanceof Person));//true
     console.log("h instanceof Object:" + (h instanceof Object));//true
     console.log("o instanceof Object:" + (o instanceof Object));//true
     console.log(typeof(h));//object
    
    

    使用typeof的一个不好的地方就是它会把Array还有用户自定义函数都返回为object.

    var j=2;
    console.log(typeof(j));//number
    console.log("j.constructor:" + j.constructor);//function
    console.log(typeof(j.constructor));//function
    

    可以看到js.constructor返回的是一些字符串,大家都应该能看到这是一个function类型,此例为Number()为Number对象的构造函数,Number()用于将其参数转换为数字number类型,并返回转换结果(若不能转换则返回 NaN)。

    因此在以后的js判断数据类型时可以使用以下方式来得到其详细数据类型

    if((typeof o=="object") && (o.constructor==Number)){}
    

     这里还要注意,constructor只能对已有变量进行判断,而typeof则可对未声明变量进行判断(返回undefined)。

  • 相关阅读:
    (转)Linux系统调用和库函数调用的区别
    一个“梦想实践重度障碍者”的思考
    按字节输出数据
    内存区划分、内存分配、常量存储区、堆、栈、自由存储区、全局区[C++][内存管理]
    VimdiffVIM的比较和合并工具
    [每天进步一点 流水账]回顾总结
    计算机就业方向
    ofstream和ifstream详细用法(转)
    ECMAScript 运算符关系运算符
    ECMAScript 语句标签语句
  • 原文地址:https://www.cnblogs.com/Bryran/p/3989328.html
Copyright © 2011-2022 走看看