美文网首页
JS静态类型检查工具Flow使用指南

JS静态类型检查工具Flow使用指南

作者: SarahZ | 来源:发表于2019-08-18 15:49 被阅读0次

TypeScript最近大火,很多人在说它与JavaScript不同之处,其中有一点必提的就是类型检查。如果我不想用TS写代码,还想对原生的JavaScript做类型检查,有没有这样的工具包呢?

FLow:https://flow.org/en/

Flow是由 facebook 开发的 JavaScript 静态类型检查工具。下面举几个例子,看看怎么使用。

安装使用

  1. npm init 生成 package.json
  2. npm install --save-dev @babel/core @babel/cli @babel/preset-flow
  3. 创建.babelrc,配置
{
  "presets": ["@babel/preset-flow"]
}
  1. npm install --save-dev flow-bin
  2. 在package.json中的脚本中添加
 "scripts": {
    "flow":"flow",
  }
  1. npm run flow init 初始化flow,生成.flowconfig
  2. 创建测试文件 test-flow.js,添加代码
function foo(x: ?number): number {
    if (x) {
        return x;
    }
    return 0;
}

foo('hi')
  1. 运行 npm run flow
image.png

类型检查成功!

几个例子

  1. 混合类型的检查

如果想要检查的类型可能是 string 也可能是 number 怎么办?Flow 也支持多种类型的检查。

function foo(value: string | number) {
  return '' + value;
}

foo(123) // Works!
foo('hi') // Works!
foo(true) // Error!
  1. 可选类型

在代码中传递 null 和 undefined 的很常见的,如何在这种情况下检查类型呢。我们需要在类型前面加一个?,比如?number

// @flow
function foo(value: ?number) {
  // ...
}

foo(42);        // Works!
foo();          // Works!
foo(undefined); // Works!
foo(null);      // Works!
foo("42");      // Error!

如果你的参数是一个对象,没有属性key,应该怎么合理检查呢?

// @flow
function foo({ value }: { value?: ?number }) {
  // ...
}

foo({ value: undefined }); // Works!
foo({});                   // Works!
  1. 类检查
// @flow

class Bar {
  x: string;          
  y: string | number; 
  z: boolean;

  constructor(x: string, y: string | number) {
    this.x = x
    this.y = y
    this.z = false
  }
}

var bar: Bar = new Bar('hello', 4)
  1. 自定义类型检查

像 Vue 、React 这样的框架不止有基本类型,肯定有自己定义的类型,那 Flow 是怎么执行检查的呢?

为了解决这类问题,Flow 提出了一个 libdef 的概念,可以用来识别这些第三方库或者是自定义类型。在.flowconfig 的 [libs] 部分用来描述包含指定库定义的目录。

Vue 就是采用 Flow 进行静态类型检查的,在源码目录下可以看到一个 .flowconfig 文件,[libs] 指向 flow 文件夹,打开文件夹,文件结构是:

flow
├── compiler.js        # 编译
├── component.js       # 组件
├── global-api.js      # Global API
├── modules.js         # 第三方库
├── options.js         # 选项
├── ssr.js             # 服务端渲染
├── vnode.js           # 虚拟 node 
├── weex.js            # weex

可以看到,Vue.js 有很多自定义类型的定义。

相关文章

  • flow.js

    flow是facebook开源的js静态类型检查工具 flow命令: flow init:启用flow, flow...

  • 【读vue 源码】溯源 import Vue from 'vue

    阅读资源 vue.js源码托管地址 flow 静态检查工具地址 rollup 源码构建 flow 静态检查工具 f...

  • JS静态类型检查工具Flow使用指南

    TypeScript最近大火,很多人在说它与JavaScript不同之处,其中有一点必提的就是类型检查。如果我不想...

  • 1:flow---在vue中的应用

    什么是flow?vue中为何用flow? flow是一个对js进行静态类型检查的工具,同作用的还有ts。js是一门...

  • Flow - JS静态类型检查工具

    zt:https://segmentfault.com/a/1190000008088489

  • flow

    flow 是 Facebook 出品的 JavaScript 静态类型检查工具。 vue 的源码利用了 flow ...

  • js语言进阶 - Flow

    flow静态类型检查工具,给javaScript提供静态类型检查能力,为其增加了一个编译的过程 开始 安装babe...

  • Flow入门初识

    Flow是facebook出品的JavaScript静态类型检查工具。由于JavaScript是动态类型语言,它的...

  • vue源码笔记

    一. Flow JavaScript 静态类型检查工具 两种工作方式: 类型推断 ;类型注释(类似ts) var ...

  • flow了解

    认识Flow - JS是动态性语言,所以要一些静态类型检查,而vue用了这个flow所以我们了解flow对我们源码...

网友评论

      本文标题:JS静态类型检查工具Flow使用指南

      本文链接:https://www.haomeiwen.com/subject/yrbrsctx.html