zoukankan      html  css  js  c++  java
  • JS区分对象类型

    Object.prototype.toString.call() 区分对象类型

    在JavaScript中数据类型分为:1.基本类型,2.引用类型

    1. 基本类型:Undefined,Boolean,String,Number,Null
    2. 引用类型:Object (Array,Date,RegExp,Function)

    var a = 'hello world';
    var b = [];
    var c = function(){};
    • 1
    • 2
    • 3

    我们用不同的判断类型的方法来判断上面三个变量的类型;(编译工具webStorm,浏览器Chrome) 
    1.首先:typeof( )

    1.console.log(typeof (a)+';'+typeof (b)+';'+typeof (c))
    输出:string;object;function
    • 1
    • 2

    2.其次:instanceof

    console.log(a instanceof Object)    //false
    console.log(b instanceof Object)    //true
    console.log(c instanceof Object)    //true
    console.log(a instanceof Array)     //false
    console.log(b instanceof Array)     //true
    console.log(c instanceof Array)     //false
    console.log(a instanceof Function)  //false
    console.log(b instanceof Function)  //false
    console.log(c instanceof Function)  //true
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    从上面两个例题可以看出,typeof(),insctanceof,这两种方法都只能对简单的变量进行判断,如果比较复杂的变量判断时就会有误,不精确; 
    下面我们介绍Object.prototype.toString.call()方法; 
    3.Object.prototype.toString.call()

    console.log(Object.prototype.toString.call(a))
    console.log(Object.prototype.toString.call(b))
    console.log(Object.prototype.toString.call(c))
    输出:
    [object String]
    [object Array]
    [object Function]
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    可以写个方法传值进入判断:

    function isType(obj,type){
            if(obj != ''){
                return Object.prototype.toString.call(obj)==='[object '+type+']'
            }else{
                alert('对象不能为空')
            }
    }
     console.log(isType('hello world','String'))  //true   
  • 相关阅读:
    HDU 2444 The Accomodation of Students (判断是否是二分图,然后求最大匹配)
    HDU 1045 Fire Net (二分匹配)
    Leangoo如何颠覆传统项目管理软件?
    团队协作神器:Leangoo
    Leangoo-让工作更简单
    leangoo 轻量级项目协作和列表管理平台
    团队协作中的“贵族”leangoo
    使用leangoo实现多泳道任务看板
    项目管理工具到底应该为谁服务?
    《精益创业实战》读书笔记
  • 原文地址:https://www.cnblogs.com/0828-li/p/9102768.html
Copyright © 2011-2022 走看看