愈来愈多人开始尝试使用 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>
更多使用方式可参考文档。性能优化
目前 vue-type-check 彻底基于 vetur 的 interpolation feature 实现,interpolation 的内部实现能够参考这篇文章。app
之因此要在 vetur 的基础上开发 vue-type-check 是为了不其局限性:编辑器
实际上在此以前咱们还尝试过其它实现方式,但最终咱们仍是转向了基于 vetur 进行开发,由于咱们但愿避免重复的开发,而且持续地将 vetur 中最新的功能和优化应用在 vue-type-check 中。函数
另外一方面 vetur 也有提供 CLI 使用方式的规划,咱们也会尝试将 vue-type-check 中完成的工做反馈给社区。性能
对于 Vue 组件模板代码的类型检查社区中也陆续进行过其它尝试,咱们从 katashin 的这篇文章了解到了几种思路的利弊。优化
由于 Vue 实际上也是将模板编译成了 JS 代码,所以能够实现一个模板 -> TS 的编译器,对编译后的结果进行类型检查。这一方式的问题是 vue-template-compiler 不能提供 source map 的支持,所以在转化以后没法标记出发生错误的位置。
参考 Angular 的方式从新实现一个类型检查器,这种方式可使用 Typescript API 的部分能力,但与 Typescript 自己还有较大差距,想要实现一些复杂的类型检查(例如函数重载、泛型)是很是困难的。
这种方式能够彻底利用 Typescript 编译器的能力,而且也能够正确标记出错误发生的位置。这也是最终 katashin 给 vetur 的 patch 中所使用的方式,目前是经过 vue-eslint-parser 完成了这一转化过程。