前言

之前学JS时候都是靠着谷狗一路跌跌撞撞的学过来,从来没有去翻过MDN的文件,导致留了许多技术债给自己。

 

最近有幸遇到一位前辈并开始从头学JS,前辈表示学程序不看文件是想作死自己?于是我的第一份功课就是读完MDN的JS入门文件,在这过程中我也笔记了一些我认为蛮重要的地方,希望藉由这三十天的过程中能加深自己印象并分享给各位。

 

如果文章中有任何的错误或引用没有附上出处也欢迎各位指教。

 

数据类型

JavaScript中,总共有七种类型:

String

Number

Boolean

Null

Undefined

Symbol(于ECMAScript 6新定义)

Object

其中又可以分成以下两大类别:

 

原始类型(Primitive type)

物件类型

除了Object其余都是原始类型

原始类型(Primitive type)

JS中最基本的单位,是一个值,因为不是物件所以没有任何属性。

 

不可变异(immutable)

所有基本类型都是不可改变的,在这里要注意的是别把变数和类型搞混了。

我们可以赋予变数一个新的值,不论是字串或是数字类型,但是却无法更改现有值。

 

物件类型

JS中除了原始类型以外的一切都是物件

 

物件这个类型代表了一种复合值(computed value),可以对他设定一些特性(properties),它们每一个都持有了可以是任何类型的值。

 

这样说听请来有点令人不知所措,来看个例子吧:

 

var obj ={

a:'hola',

b:42,

c:true

}

obj.a;// 'hola'

obj.b;//42

obj.c;//true

辨别类型:

用typeof可以判断上述中除了null的值

 

var myStr = 'hello world';

typeof myStr;//“string”

typeof 'hello world';//“string”

 

var myNum = 42;

typeof myNum;//“number”

typeof 42;//“number”

 

var myBol = true;

typeof myBol;//“boolean”

typeof true;//“boolean”

 

var myUndefined;

typeof myUndefined;//“undefined”

typeof undefined;//“undefined”

 

typeof null;//“object”

var myObj = {

a:'hola',

}

typeof myObj;//“object”

使用typeof(null)===“object”是早期JS设计时候的Bug。

 

JS会让这bug存在这么久(大概快二十年)原因在于很多网站仰赖这个bug如果修正可能会产生更多的bug。

 

参考:

MDN Primitive

JavaScript的数据类型与数据结构

 

你所不知道的JS导读、类型与文法