Vue.js源码--准备工作

Vue.js源码--准备工作_第1张图片

1.认识flow

Flow 是 facebook 出品的 JavaScript 静态类型检查⼯具。Vue.js 的源码利⽤了 Flow 做了静态类型检查, 所以了解 Flow 有助于我们阅读源码。

为什么⽤ Flow

JavaScript 是动态类型语⾔,它的灵活性有⽬共睹,但是过于灵活的副作⽤是很容易就写出⾮常隐蔽的隐患代码,在编译期甚⾄看上去都不会报错,但在运⾏阶段就可能出现各种奇怪的 bug。

类型检查是当前动态类型语⾔的发展趋势,所谓类型检查,就是在编译期尽早发现(由类型错误引起的)bug,⼜不影响代码运⾏(不需要运⾏时动态检查类型),使编写 JavaScript 具有和编写 Java 等强类型语⾔相近的体验。

项⽬越复杂就越需要通过⼯具的⼿段来保证项⽬的维护性和增强代码的可读性。 Vue.js 在做 2.0 重构的时候,在 ES2015 的基础上,除了 ESLint 保证代码⻛格之外,也引⼊了 Flow 做静态类型检查。之所以选择 Flow,主要是因为 Babel 和 ESLint 都有对应的 Flow 插件以⽀持语法,可以完全沿⽤现有的构建配置,⾮常⼩成本的改动就可以拥有静态类型检查的能⼒。

Flow 的⼯作⽅式

通常类型检查分成 2 种⽅式:

类型推断:通过变量的使⽤上下⽂来推断出变量类型,然后根据这些推断来检查类型。类型注释:事先注释好我们期待的类型,Flow 会基于这些注释来判断。

类型判断

它不需要任何代码修改即可进⾏类型检查,最⼩化开发者的⼯作量。它不会强制你改变开发习惯,因为它会⾃动推断出变量的类型。这就是所谓的类型推断,Flow 最重要的特性之⼀。

通过⼀个简单例⼦说明⼀下:

 

 

 

function split(str) { return str.split(' ')

}

Flow 检查上述代码后会报错,因为函数 split 期待的参数是字符串,⽽我们输⼊了数字。

类型注释

 

 

如上所述,类型推断是 Flow 最有⽤的特性之⼀,不需要编写类型注释就能获取有⽤的反馈。但在某些特定的场景下,添加类型注释可以提供更好更明确的检查依据。

function add(x, y){ return x + y

}

Flow 检查上述代码时检查不出任何错误,因为从语法层⾯考虑, + 即可以⽤在字符串上,也可以⽤在数字上,我们并没有明确指出 add() 的参数必须为数字。

在这种情况下,我们可以借助类型注释来指明期望的类型。类型注释是以冒号 : 开头,可以在函数参数,返回值,变量声明中使⽤。

如果我们在上段代码中添加类型注释,就会变成如下:

function add(x: number, y: number): number { return x + y

}

现在 Flow 就能检查出错误,因为函数参数的期待类型为数字,⽽我们提供了字符串。

上⾯的例⼦是针对函数的类型注释。接下来我们来看看 Flow 能⽀持的⼀些常⻅的类型注释。

 

 
 

数组

var arr: Array = [1, 2, 3] arr.push('Hello')

数组类型注释的格式是 Array , T 表⽰数组中每项的数据类型。在上述代码中,arr 是每项均为数字的数组。如果我们给这个数组添加了⼀个字符串,Flow 能检查出错误。

 

 
 

类和对象

 

Vue.js源码--准备工作_第2张图片

类的类型注释格式如上,可以对类⾃⾝的属性做类型检查,也可以对构造函数的参数做类型检查。这

⾥需要注意的是,属性  y 的类型中间⽤  | 做间隔,表⽰  y 的类型即可以是字符串也可以是数字。

对象的注释类型类似于类,需要指定对象属性的类型。

类的类型注释格式如上,可以对类⾃⾝的属性做类型检查,也可以对构造函数的参数做类型检查。这

⾥需要注意的是,属性  y 的类型中间⽤  | 做间隔,表⽰  y 的类型即可以是字符串也可以是数字。

对象的注释类型类似于类,需要指定对象属性的类型。

Null

若想任意类型 T 可以为 null 或者 undefined ,只需类似如下写成 ?T 的格式即可。

 

var foo: ?string = null

 

此时, foo 可以为字符串,也可以为 null 。

⽬前我们只列举了 Flow 的⼀些常⻅的类型注释。如果想了解所有类型注释,请移步 Flow 的官⽅⽂

 

Flow Vue.js 源码中的应⽤

有时候我们想引⽤第三⽅库,或者⾃定义⼀些类型,但 Flow 并不认识,因此检查的时候会报错。为了解决这类问题,Flow 提出了⼀个 libdef 的概念,可以⽤来识别这些第三⽅库或者是⾃定义类型,

⽽ Vue.js 也利⽤了这⼀特性。

在 Vue.js 的主⽬录下有 .flowconfig ⽂件, 它是 Flow 的配置⽂件,感兴趣的同学可以看官⽅⽂。这其中的 [libs] 部分⽤来描述包含指定库定义的⽬录,默认是名为 flow-typed 的⽬录。

 

 

这⾥  [libs] 配置的是  flow ,表⽰指定的库定义都在  flow ⽂件夹内。我们打开这个⽬录,会发现⽂件如下:

 

Vue.js源码--准备工作_第3张图片
 
 
 
 

 

 
 

可以看到,Vue.js 有很多⾃定义类型的定义,在阅读源码的时候,如果遇到某个类型并想了解它完整的数据结构的时候,可以回来翻阅这些数据结构的定义。

总结

通过对 Flow 的认识,有助于我们阅读 Vue 的源码,并且这种静态类型检查的⽅式⾮常有利于⼤型项⽬源码的开发和维护。类似 Flow 的⼯具还有如 TypeScript,感兴趣的同学也可以⾃⾏去了解⼀下。

 

你可能感兴趣的:(vue.js)