最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JavaScript基础(2-2)数据类型检测

    正文概述 掘金(甘草倚半夏)   2021-04-01   600

    typeof :检测数据类型的运算符,返回的结果是字符串

    返回的结果是字符串,字符串中的内容证明了这个值是属于什么类型的

    1. 基础数据类型除了typeof null'object'以外,typeof都是自己的数据类型
    2. 引用数据类型分为:对象数据类型函数数据类型
    3. 对象数据类型分为:{} 普通对象型,[] 数组, /^$/ 正则日期对象
    4. 对象数据类型nulltypeof都是‘object’
    5. 函数数据类型typeof都是‘function’

    局限性:

    1. typeof null 不是'null' 而是 'object' :因为null虽然是单独的一个数据类型,但是它原本意思是空对象指针,浏览器用typeof 检测 的时候会把它当做对象来检测
    2. 使用typeof 无法具体细分出 到底是数组还是正则 ,因为返回结果 都是 'object'

    面试题:

    typeof typeof  []   => 'string'
    //1、typeof  []  =》  'object'
    //2、typeof 'object'  =》 'string'
    
    	typeof 12 => 'number'
    
    	var num=13;
    	typeof num => 'number'
    	typeof 'aaa'=> 'string'
    	typeof true => 'boolean'
    	typeof null => 'object'    //typeof 的bug
    	typeof undefined => 'undefined'
    
    	typeof {aaa:'aaa'}  =>  'object'
    	typeof []   =>   'object'
    	typeof /^$/  =>  'object'
    	typeof function (){}  =>  'function'
    

    XX instanceof YY,检测当前实例是否属于某个类

    function Fn(){
    
    }
    var f=new Fn();
    
    console.log(f instanceof Fn)        //=>true
    
    [] instanceof Array    true
    [] instanceof Object   true
    
    console.log([] instanceof Array)    //=>true
    console.log(/^$/ instanceof Fn)     //=>false
    
    [] instanceof Object                //true
    /^$/ instanceof Object              //true
    /^$/ instanceof Array               //false
    [] instanceof Array                 //true
    /^$/ instanceof RegExp              //true
    
    function aaa(){}
    console.log(aaa instanceof Function)  //true
    

    手动实现instanceof

    instanceof 用于判断某个对象是否是另一个对象(构造方法)的实例。 instanceof会查找原型链,直到null如果还不是后面这个对象的实例的话就返回false,否则就返回true

    function instanceofMy(obj, constructor) {
      // 错误判断 构造函数必须是一个function 其他的均报错
      if (typeof constructor !== 'function') throw new Error('instance error')
      if (!obj || (typeof obj !== 'object' && typeof obj !== 'function')) return false
      // 获取到原型对象
      let proto = constructor.prototype
      // 如果obj的原型对象不是null
      while (obj.__proto__) {
        if (obj.__proto__ === proto) return true
        obj = obj.__proto__
      }
      return false
    }
    
    console.log(instanceofMy(() => {}, Function)) // true
    

    xxx.constructor: 获取当前实例的构造器

    var test=1;
    //var test=[1];
    //var test='1';
    
    if (test.constructor==Array)
    {
        console.log("This is an Array");
    }
    if (test.constructor==Boolean)
    {
        console.log("This is an Boolean");
    }
    if (test.constructor==Date)
    {
        console.log("This is an Date");
    }
    if (test.constructor==String)
    {
        console.log("This is an String");
    }
    if (test.constructor==Number)
    {
        console.log("This is an Number");
    }
    
    var test=[1];
    console.log(test.constructor == Object); //false
    
    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,job,born) {
        this.name=name;
        this.job=job;
        this.born=born;
    }
    

    Object.prototype.toString.call : 获取当前实例的所属类信息

    判断基本类型:

    Object.prototype.toString.call(null); // "[object Null]"
    Object.prototype.toString.call(undefined); // "[object Undefined]"
    Object.prototype.toString.call("abc");// "[object String]"
    Object.prototype.toString.call(123);// "[object Number]"
    Object.prototype.toString.call(true);// "[object Boolean]"
    

    判断原生引用类型:

    //**函数类型**
    Function fn(){
      console.log(“test”);
    }
    Object.prototype.toString.call(fn); // "[object Function]"
    
    //**日期类型**
    var date = new Date();
    Object.prototype.toString.call(date); // "[object Date]"
    
    //**数组类型**
    var arr = [1,2,3];
    Object.prototype.toString.call(arr); // "[object Array]"
    
    //**正则表达式**
    var reg = /[hbc]at/gi;
    Object.prototype.toString.call(reg); // "[object RegExp]"
    
    //判断原生JSON对象
    var isNativeJSON = window.JSON && Object.prototype.toString.call(JSON);
    console.log(isNativeJSON);// 输出结果为”[object JSON]”说明JSON是原生的,否则不是;
    
    //**自定义类型**
    function Person(name, age) {
        this.name = name;
        this.age = age;
    }
    var person = new Person("Rose", 18);
    Object.prototype.toString.call(person); // "[object Object]" //能准确判断person是Person类的实例
    

    对于我们自己定义的类型

    比如 function Fn() {},则需要设置 知名符号 toStringTag来设置

    Fn.prototype[Symbol.toStringTag] = 'Fun'
    
    Object.prototype.toString.call(new Fn()) // "[object Fun]"
    

    起源地下载网 » JavaScript基础(2-2)数据类型检测

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元