0

0

如何在vscode中配置TypeScript环境并编译代码【教程】

紅蓮之龍

紅蓮之龍

发布时间:2026-01-17 18:24:09

|

274人浏览过

|

来源于php中文网

原创

VS Code 中 TypeScript 不编译是因为缺少 tsc 编译器而非插件;需安装 typescript(推荐本地 npm install --save-dev typescript),配置 tsconfig.json,并通过 tasks.json 设置 tsc 监听任务实现保存自动编译。

如何在vscode中配置typescript环境并编译代码【教程】

VS Code 里 TypeScript 不报错但不编译,缺的是 tsc 而不是插件

VS Code 自带 TypeScript 语言服务(语法检查、跳转、补全),但默认**不会自动编译 .ts 文件为 .js**。你看到的“类型检查正常”只是编辑器在用内置 TS Server 做静态分析,和编译完全无关。真正触发编译需要外部命令 tsc —— 它来自 TypeScript 编译器包,必须显式安装。

  • 全局安装:npm install -g typescript(之后终端能直接运行 tsc
  • 项目本地安装更推荐:npm install --save-dev typescript,然后通过 npx tsc 调用
  • 装完后在终端执行 tsc -v,确认输出版本号(如 5.4.5),否则后续所有编译步骤都无效

tsconfig.json 是编译行为的唯一控制中心

没有 tsconfig.jsontsc 只会做最基础的单文件转换(且忽略所有配置),无法处理模块、路径别名、JSX、目标环境等关键逻辑。必须手动初始化或创建它。

  • 在项目根目录运行 npx tsc --init,生成默认配置文件
  • 关键字段要手动改:比如 "outDir": "./dist" 指定输出目录,"rootDir": "./src" 声明源码位置,"target": "ES2020" 控制生成 JS 版本
  • 如果项目含 JSX,必须设 "jsx": "react-jsx";用 Node.js 后端则建议 "module": "commonjs"
  • 删掉 // 开头的注释行——tsc 不认注释,会导致解析失败
{
  "compilerOptions": {
    "target": "ES2020",
    "module": "commonjs",
    "lib": ["ES2020", "DOM"],
    "outDir": "./dist",
    "rootDir": "./src",
    "strict": true,
    "esModuleInterop": true,
    "skipLibCheck": true,
    "forceConsistentCasingInFileNames": true
  },
  "include": ["src/**/*"]
}

tasks.jsontsc 接进 VS Code 快捷键

不想每次打开终端敲 npx tsc?VS Code 的任务系统可以绑定到快捷键(如 Ctrl+Shift+B),但前提是正确配置 .vscode/tasks.json

  • Ctrl+Shift+P → 输入 “Tasks: Configure Task” → 选 “Create tasks.json from template” → 选 “Others”
  • 替换内容为以下结构,重点看 commandargs:本地安装就用 npx tsc,全局安装可直接写 tsc
  • isBackground 设为 true 才能支持监听模式(--watch),否则每次编译完就退出
{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "tsc: watch",
      "type": "shell",
      "command": "npx tsc",
      "args": ["--watch"],
      "group": "build",
      "isBackground": true,
      "problemMatcher": ["$tsc-watch"]
    }
  ]
}

配好后按 Ctrl+Shift+B,选择 “tsc: watch”,终端就会启动监听——保存 .ts 文件自动重新编译。

来福FM
来福FM

来福 - 你的私人AI电台

下载

常见报错直接对应配置项

编译失败时,错误信息里的关键词基本能定位到 tsconfig.json 的哪个字段没设对:

  • Cannot find module 'xxx' → 检查 "baseUrl""paths" 是否配了路径映射,或 "moduleResolution" 是否为 "node"
  • JSX element type does not have any construct or call signatures"jsx" 没设,或 "lib""DOM"
  • 输出 JS 里还有 import/export 未被转换 → "module" 值不匹配运行环境(浏览器要用 "ESNext",Node 用 "commonjs"
  • error TS5055: Cannot write file ... because it would overwrite input file"outDir""rootDir" 路径重叠,比如都设成了 "./src"

编译是纯命令行行为,和 VS Code 主题、插件开关、设置里的 “TypeScript > Suggest: Auto Imports” 都无关。只要 tsc 能在终端跑通,VS Code 里的编译任务就大概率能跑通。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

412

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

187

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.10.25

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

510

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

40

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.7万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号