美文网首页
js基础数据类型和判断方法

js基础数据类型和判断方法

作者: day_day_up | 来源:发表于2017-03-27 11:00 被阅读0次

    js六大数据类型

    number、string、object、Boolean、null、undefined

    string: 由单引号或双引号来说明,如"string"
    number:什么整数啊浮点数啊都叫数字,你懂的~
    Boolean: 就是true和false啦
    undefined:未定义,就是你创建一个变量后却没给它赋值~
    null: 故名思久,null就是没有,什么也不表示
    object: 这个我也很难解释的说。就是除了上面五种之外的类型

    数据类型判断之 typeof

    var a="string"; console.log(a); //string
    var a=1; console.log(a); //number
    var a=false; console.log(a); //boolean
    var a; console.log(typeof a); //undfined
    
    var a = null; console.log(typeof a); //object
    var a = document; console.log(typeof a); //object
    var a = []; console.log(a); //object
    
    var a = function(){}; console.log(typeof a) //function   除了可以判断数据类型还可以判断function类型
    

    这样一来就很明显了,除了前四个类型外,null、对象、数组返回的都是object类型;
    对于函数类型返回的则是function,再比如typeof(Date),typeof(eval)等。
    然后这里就可以再引申出另一个灰常热门并且解决方法已普遍存在的问题,如何判断数据是个数组类型?

    js判断数组类型的方法

    1.instanceof
    var a=[];
    console.log(a instanceof Array) //返回true 
    
    2.constructor
    function employee(name,job,born){
        this.name=name;
        this.job=job;
        this.born=born;
    }
    
    var bill=new employee("Bill Gates","Engineer",1985);
    console.log(bill.constructor); //输出function employee(name, jobtitle, born){this.name = name; this.jobtitle = job; this.born = born;}
    
    console.log([].constructor == Array);
    console.log({}.constructor == Object);
    console.log("string".constructor == String);
    console.log((123).constructor == Number);
    console.log(true.constructor == Boolean);
    

    较为严谨并且通用的方法:

    function isArray(object){
        return object && typeof object==='object' &&
                Array == object.constructor;
    }
    

    !!注意:

    使用instaceof和construcor,被判断的array必须是在当前页面声明的!比如,一个页面(父页面)有一个框架,框架中引用了一个页面(子页面),在子页面中声明了一个array,并将其赋值给父页面的一个变量,这时判断该变量,Array == object.constructor;会返回false;
    原因:
    1、array属于引用型数据,在传递过程中,仅仅是引用地址的传递。
    2、每个页面的Array原生对象所引用的地址是不一样的,在子页面声明的array,所对应的构造函数,是子页面的Array对象;父页面来进行判断,使用的Array并不等于子页面的Array;切记,不然很难跟踪问题!

    方法三之 特性判断法

    function isArray(object){
        return  object && typeof object==='object' &&    
                typeof object.length==='number' &&  
                typeof object.splice==='function' &&    
                 //判断length属性是否是可枚举的 对于数组 将得到false  
                !(object.propertyIsEnumerable('length'));
    }
    

    方法四之 最简单的方法

    function isArray(o) {
        return Object.prototype.toString.call(o) === ‘[object Array]‘;
    }
    

    这种方式既解决了instanceof存在的跨页面问题,也解决了属性检测方式所存在的问题,实在是一种妙招,一个很好的解决方案。
    除此之外,这种解决办法也可以应用于判断Date,Function等类型的对象。

    相关文章

      网友评论

          本文标题:js基础数据类型和判断方法

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