美文网首页LiYajie web前端
web前端-数据类型, 以及类型判断

web前端-数据类型, 以及类型判断

作者: LiYajie | 来源:发表于2017-03-26 15:33 被阅读20次

    数据类型

    基本数据类型(值类型)

    • string 字符串类型
    • number 数值类型
    • boolean 布尔类型(true | false)
    • null
    • undefined 未定义

    复杂数据类型(引用数据类型)

    • Object 对象类型 --> object
    • Array 数组类型 --> object
    • Date 日期类型 --> object
    • Math 数学函数 --> object
    • Function 函数类型 --> function(并非object)
    • RegExp 正则表达式
    • String 字符串类型
    • Number 数值对象类型
    • Boolean 布尔对象类型

    判断数据类型 使用typeof关键字, typeof 返回的数据是string类型的

    var str = 'abc';
    var num = 111;
    var flag = true;
    var arr = [];
    var date = new Date();
    var fun = new Function();
    var reg = new RegExp('/\g');
    
    console.log(typeof str);// string
    console.log(typeof num);// number
    console.log(typeof flag);// boolean
    console.log(typeof arr);// object
    console.log(typeof Math);// object
    console.log(typeof date);// object
    console.log(typeof fun);// function
    console.log(typeof null);// object
    console.log(typeof undefined);// undefined
    console.log(typeof reg);// object
    

    注意: ECMA-262规定任何内部实现[[Call]]方法的对象都应该在使用typeof的时候返回'function' Safari 5之前和Chrome7之前版本中就实现了Call, 所以这些版本在检测正则表达式的时候会返回function

    typeof检查数据类型的时候很好用, 但是检查引用类型的值的时候却不怎么给力, 所以要使用intanceof操作符, 但是此此操作符也有问题, 如下:

    var str = 'abc';
    var str2 = new String('bbb');
    var num = 111;
    var num2 = new Number(11);
    var flag = true;
    var flag2 = new Boolean(false);
    var arr = [1,2,3];
    var date = new Date();
    var fun = new Function();
    var reg = new RegExp('/\g');
    
    console.log(str instanceof String);// false
    console.log(str2 instanceof String);// true
    console.log(num instanceof Number);// false
    console.log(num2 instanceof Number);// true
    console.log(flag instanceof Boolean);// false
    console.log(flag2 instanceof Boolean);// true
    console.log(arr instanceof Array);// true
    console.log(date instanceof Date);// true
    console.log(fun instanceof Function);// true
    console.log(reg instanceof RegExp);// true
    

    下面这种检测类型方式最好使, 我们只需要截取出结果做比较即可.

    var str = 'abc';
    var str2 = new String('bbb');
    var num = 111;
    var num2 = new Number(11);
    var flag = true;
    var flag2 = new Boolean(false);
    var arr = [1,2,3];
    var date = new Date();
    var fun = new Function();
    var reg = new RegExp('/\g');
    var jsonObj = {};
    
    console.log(Object.prototype.toString.call(str));// [object String]
    console.log(Object.prototype.toString.call(str2));// [object String]
    console.log(Object.prototype.toString.call(num));// [object Number]
    console.log(Object.prototype.toString.call(num2));// [object Number]
    console.log(Object.prototype.toString.call(flag));// [object Boolean]
    console.log(Object.prototype.toString.call(flag2));// [object Boolean]
    console.log(Object.prototype.toString.call(arr));// [object Array]
    console.log(Object.prototype.toString.call(date));// [object Date]
    console.log(Object.prototype.toString.call(fun));// [object Function]
    console.log(Object.prototype.toString.call(reg));// [object RegExp]
    console.log(Object.prototype.toString.call(Math));// [object Math]
    console.log(Object.prototype.toString.call(jsonObj));// [object Object]
    
    var person = new Person();
    console.log(person instanceof Person); // true
    

    因为任何对象的超类都是Object , 所以任何对象使用instanceof Object 都会返回true

    console.log(person instanceof Object); // true
    

    相关文章

      网友评论

        本文标题:web前端-数据类型, 以及类型判断

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