web前端-数据类型, 以及类型判断
2017-03-26 本文已影响20人
LiYajie
数据类型
基本数据类型(值类型)
string
字符串类型number
数值类型boolean
布尔类型(true | false)null
空undefined
未定义
复杂数据类型(引用数据类型)
Object
对象类型 --> objectArray
数组类型 --> objectDate
日期类型 --> objectMath
数学函数 --> objectFunction
函数类型 --> 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