vue-type-check: Vue 模板中的 Typescript 类型检查

愈来愈多人开始尝试使用 Typescript 编写他们的 Vue 项目,Vue 自己也在不断增强对 Typescript 的支持(官方提供 vue-class-component 库、使用 Typescript 编写 Vue 3.0 等),可是对于组件中模板部分的类型检查仍然有很大的局限性。html

为此咱们开源了一个易于使用的 Vue 类型检查器: vue-type-check,能够对 Typescript 编写的 Vue 组件中模板和脚本的部分均进行类型检查。vue

vue-type-check 同时提供了 CLI 和 API 两种使用方式,而且输出清晰的错误提示以便和现有的工做流无缝衔接。git

示例

咱们对如下 Vue 单文件组件进行类型检查,其中包含了两个类型错误:github

  • 在模板中使用的变量 msg 并无在组件中定义。
  • printMessage 方法中错误地对字符串类型的值使用 toFixed 方法。
<template>
  <div id="app">
    <p>{{ msg }}</p>
  </div>
</template>

<script lang="ts">
import Vue from "vue";

export default Vue.extend({
  name: "app",
  data() {
    return {
      message: "Hello World!"
    };
  },
  methods: {
    printMessage() {
      console.log(this.message.toFixed(1));
    }
  }
});
</script>

example.gif

更多使用方式可参考文档性能优化

工做原理

目前 vue-type-check 彻底基于 veturinterpolation feature 实现,interpolation 的内部实现能够参考这篇文章app

之因此要在 vetur 的基础上开发 vue-type-check 是为了不其局限性:编辑器

  • vetur 以 vscode 编辑器插件的形式存在,不能很好地和持续集成等工做流进行集成,使用场景有限。
  • vetur interpolation 目前仍是实验性功能,而且因为实现方式较为 hack,所以使用时稳定性还有所欠缺,实际使用时会遇到 vue language server crash 须要重启的问题。相比之下 vue-type-check 只对已经完成编辑的文件进行类型检查,稳定性更佳。
  • vetur interpolation 还未作太多的性能优化,在咱们一个有大量自动生成的 Typescript 代码的项目中会致使 vscode 很是卡顿。

实际上在此以前咱们还尝试过其它实现方式,但最终咱们仍是转向了基于 vetur 进行开发,由于咱们但愿避免重复的开发,而且持续地将 vetur 中最新的功能和优化应用在 vue-type-check 中。函数

另外一方面 vetur 也有提供 CLI 使用方式的规划,咱们也会尝试将 vue-type-check 中完成的工做反馈给社区。性能

其它尝试

对于 Vue 组件模板代码的类型检查社区中也陆续进行过其它尝试,咱们从 katashin这篇文章了解到了几种思路的利弊。优化

方式一:将 Vue 模板编译后进行检查

由于 Vue 实际上也是将模板编译成了 JS 代码,所以能够实现一个模板 -> TS 的编译器,对编译后的结果进行类型检查。这一方式的问题是 vue-template-compiler 不能提供 source map 的支持,所以在转化以后没法标记出发生错误的位置。

方式二:实现一个类型检查器

参考 Angular 的方式从新实现一个类型检查器,这种方式可使用 Typescript API 的部分能力,但与 Typescript 自己还有较大差距,想要实现一些复杂的类型检查(例如函数重载、泛型)是很是困难的。

方式三:将模板转化为 Typescript AST

这种方式能够彻底利用 Typescript 编译器的能力,而且也能够正确标记出错误发生的位置。这也是最终 katashin 给 vetur 的 patch 中所使用的方式,目前是经过 vue-eslint-parser 完成了这一转化过程。

相关文章
相关标签/搜索