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

数据类型

基本数据类型(值类型)

  • 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

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 2,556评论 0 4
  • 本章内容 使用对象 创建并操作数组 理解基本的 JavaScript 类型 使用基本类型和基本包装类型 引用类型的...
    闷油瓶小张阅读 508评论 0 0
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 128,834评论 18 137
  • 这不是一篇学术文章。 《身体知道答案》(武志红著) 如果我们能喝善舞,我们可以通过舞蹈歌唱来表达自己,表达真实的自...
    四只脚的团子阅读 112评论 0 0
  • 包子,应该是中国的早餐界里数一数二的招牌。 一笼包子配上一碗稀饭,再来点自家泡的小菜。吃一口包子喝一口稀饭,一笼包...
    她栀阅读 363评论 0 2
  • 产品狗总把“以用户为中心”挂在嘴边。既然要以“用户为中心”,我们就要更好地了解用户。了解用户,常用的办法就是用户研...
    肥寒925阅读 741评论 0 11
  • 今年的暑假《小黄人大眼萌》给大家带来了无限欢乐,这种又萌又贱的生物一开始是《神偷奶爸》系列中的小配角,因其高人气就...
    电影探照灯阅读 3,203评论 0 0