LiYajie web前端

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

2017-03-26  本文已影响20人  LiYajie

数据类型

基本数据类型(值类型)

  • 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
上一篇下一篇

猜你喜欢

热点阅读