JavaScript类型系统详解

基本数据类型

ECMAScript中有5种简单数据类型(也称基本数据类型):Undefined,Null,Boolean,Number和String。还有一种复杂数据类型(引用型)Object。ECMAScript不支持任何创建自定义类型的机制,而所有值都是上述6中数据类型之一。(ps:ES6新增了一种数据类型Symbol,这里不做讨论)

Undefined

  • 值:undefined

  • 出现场景:

    • 使用var声明变量未赋值(相当于var test = undefined;

    • 获取对象不存在的属性

    • 无返回值的函数的执行结果

    • 函数的参数没有传入

    • void(expression)

  • 类型转换:

-BooleanNumberString
undefinedfalseNaN"undefined"

Null

  • 值:null。null值表示一个空对象指针,若定义的一个变量准备将来用来保存一个对象,那么最好将变量初始化为一个null

  • 出现场景:

    • var test = null;

    • null表示调用的对象不存在

注意区分null和undefined的区别?

null == undefined;  // true
null === undefined; // false
  • 类型转换

-BooleanNumberString
nullfalse0"null"

Boolean

  • 值:true or false。

  • 出现场景:

    • 条件语句导致系统执行的隐式装换

    • 定义

  • 类型转换

-numberstring
true1"true"
false0"false"

String

  • 值:由单引号或双引号括起来的字符序列

  • 出现场景:定义

  • 类型转换,有两种方法,String()toString()

-BooleanNumber
""false0
"123"true123
"a12"trueNaN

Number

  • 值:整数和浮点值

  • 出现场景:

  • 类型转换,Number()parseInt()parseFloat()。第一个函数可以应用于任何数据类型,另两个函数专门用于把字符串转换成数值

-BooleanString
0false0
1true1
Infinitytrue"Infinity"
NaNfalse"NaN"

Object

  • 值:一组属性的集合

  • 出现场景:

  • 类型转换

-BooleanNumberString
{}trueNaN"[object Object]"

类型识别

typeof(操作符,不是函数)

  • 可以识别简单类型(Null除外)

  • 不能识别具体的对象类型(Function除外)

typeof "darko"; //"string"
typeof 123;     //"number"
typeof true;    //"boolean"
typeof undefined;    //"undefined"
typeof null;     //"object"
typeof {name:"darko"};  //"object"

typeof function(){};    // "function"
typeof [];      // "object"
typeof new Date();  //"object"

instanceof(三目运算符)

  • 识别内置对象的类型

  • 不可以识别简单类型

  • 识别自定义对象类型

[] instanceof Array;    //true
/\d/ instanceof RegExp; //true

1 instanceof Number;    //false
"abc" instanceof String;  //false

constructor

  • 识别简单类型(undefined和null除外)

  • 识别内置对象类型

  • 识别自定义对象类型

(1).constructor === Number; // true
true.constructor === Boolean; // true

[].constructor === Array;   // true

Object.prototype.toString

  • 可以简单类型和内置对象

  • 不能识别自定义类型

function type(obj){
    return Object.prototype.toString.call(obj).slice(8, -1).toLowerCase();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值