Vue 3 + TypeScript 项目,为什么 serve 和 build 的时候都不报任何 TS 编译错误?

2021-02-22 18:35:45 +08:00
 shintendo

我在组件的<script>段里写了一些错误的语句,VSCode 检查出来了并且标红了,但当我执行 npm run serve 的时候,都能顺利跑起来并且没有任何报错,请问这个情况是否正常?如果不正常的话,我稍后可以提供代码。

4406 次点击
所在节点    Vue.js
16 条回复
EPr2hh6LADQWqRVH
2021-02-22 18:41:16 +08:00
正常,vue 默认的 tsconfig 是 transpileOnly, 新一点的 vite 工具链甚至都不用 tsc,对 TypeScript 的态度就是闹着玩
Jirajine
2021-02-22 18:52:21 +08:00
很正常啊, 忽略类型检查能加快编译打包速度,而 typescript 提供的类型检查功能可以直接通过 language server 使用。
beginor
2021-02-22 23:23:57 +08:00
只能说 vue 对 ts 的支持比较差, 比 angular 和 react 差很多, 我在 vue 项目中都要设置 skipLibraryCheck 为 true 才能运行 tsc, 否则一大堆错误
faceRollingKB
2021-02-23 09:57:01 +08:00
终于看到踩坑 vue3 的了
shintendo
2021-02-23 10:08:24 +08:00
@faceRollingKB 个人项目玩玩
shintendo
2021-02-23 10:09:16 +08:00
@avastms
@Jirajine
那请问有什么配置选项可以开启检查吗?比如我希望有类型错误的时候中止编译
miloooz
2021-02-23 11:37:51 +08:00
@beginor 还好吧 我用脚手架生成的 ts 版 3.0 的 ,没报错欸。然后用 tsx 去写,感觉代码提示上和 react 差距不是很大了。
zhangyuang
2021-02-23 13:32:09 +08:00
vue+ts 不是用来检查类型的。你可以单独搞一个 server:types: tsc -p 用 tsc 来单独检测类型错误
shintendo
2021-02-23 13:59:01 +08:00
@zhangyuang 呃,不太明白,那 vue+ts 仅仅为了代码提示吗?
Jirajine
2021-02-23 14:25:23 +08:00
@shintendo 当然可以,配置取决于你的打包工具,一般为了打包速度会默认使用 babel 或 esbuild 来转译 ts,你可以显式指定为 tsc,并配置好 tsconfig.json 。
但这样其实没太大必要,会大幅度拖慢打包速度。类型检查 language server 已经帮你做了,有错误都能提示出来。
换用 snowpack/vite 这些基于 esm 的开发工具能快一些。
zhangyuang
2021-02-23 14:33:10 +08:00
@shintendo 你可以这么理解。。其实 react+ts 也只是为了代码提示。因为 ts-loader 和 babel-react-app 的 ts 选项也都不会进行类型检查。只是单纯的 transform 代码
shintendo
2021-02-23 14:41:38 +08:00
@Jirajine
我是 vue-cli 生成的项目,你说的“显式指定为 tsc”是在什么地方配置的呢?
关于 language server 的提示,我的问题是它只提示当前打开的文件中的错误,而不检查项目中其它文件中可能存在的错误,这个是我的设置问题吗?
Jirajine
2021-02-23 15:24:21 +08:00
@shintendo 我记得 vue-cli 生成项目用的是 webpack,那你只要配置转译 typescript 的为 ts-loader 而不是 babel-loader,然后 tsconfig.json 里开启需要的选项。
具体参考 https://cli.vuejs.org/core-plugins/typescript.html
https://github.com/TypeStrong/ts-loader
stkevintan
2021-02-23 22:10:15 +08:00
这不是对 ts 不友好,而是一种优化手段,可能小项目不会感觉 tsc 有多慢,在我软 ts 大型项目比比皆是,编译起来速度感人。
一般类型检查通过编辑器就能解决一大部分,如果实在要检查的话一般是用这个插件 https://www.npmjs.com/package/fork-ts-checker-webpack-plugin
charlie21
2021-02-25 10:56:31 +08:00
一个 lint 为什么要报错?
“(在类型擦除的层面看) TypeScript 本质上是一个 JS linter (给出报错提示,在编辑器里,在编辑时)”
https://www.cnblogs.com/powertoolsteam/p/13500668.html
https://www.typescriptlang.org/docs/handbook/typescript-from-scratch.html#erased-types
Reol
2021-03-04 14:08:42 +08:00
加 eslint 是不是应该就能报错?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/755195

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX