怎么打造一个舒适的nodejs开发环境

目标:需要根据node的版本,提供代码的提示和报错。

使用场景:编写nodejs代码,直接运行,不经过ts编译。需要编辑和运行时一致,在编辑时提供提示和报错。

1、使用ts

可以在项目中配置 jsconfig.json/tsconfig.json, 结合 @types/node 和 @tsconfig.json。

配置之后,编写代码时可以做到api特性的提示和报错。

但是对语法特性,是没法根据ES的版本进行报错的,比如下面这个代码:

js 复制代码
let x1 = 5;
x1 &&= 10;

&&=是es2021的特性,在node14中直接运行会报错。需要先进行tsc编译。

如果想直接运行js而不进行ts编译,希望编辑器给出报错提示。这个时候只配置ts就不够了,需要结合eslint。

2、使用eslint

eslint中可以配置:

js 复制代码
languageOptions: {
      ecmaVersion: 6,
      sourceType: "script"
}

一些疑问

问题1

配置tsconfig后,会根据lib来检查代码中使用的es的api。但是没法对语法特性进行检查,ts会对语法特性进行转义。问题:

  1. ts是怎么识别最新的语法特性的,并转译的
  2. ts为什么不能对语法特性进行报错

猜想1:与server服务的ts版本有关,ts版本决定了识别的语法特性。

确实有关。需要考虑 ts版本对es语法特性的支持,哪里可以看到具体的对应关系?

也可以去 typescript 官网看版本日志:www.typescriptlang.org/docs/handbo...

不同版本的ts支持的特性不一样,验证:可以去 ts在线网站去验证:www.typescriptlang.org/play/?ts=3....

举个例子:ts3.9.7版本不支持 a||=4, 但是 4.0.5 版本支持。

那如果我要禁用高版本的语法特性,我就只能使用低版本的ts吗?有没有个选项可以配置?貌似没有,只能配合eslint

相关推荐
雪碧聊技术5 小时前
前端项目代码发生改变,如何重新部署到linux服务器?
前端·vue3·centos7·代码更新,重新部署
liulilittle6 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
wordbaby6 小时前
Expo 进阶指南:赋予 TanStack Query “原生感知力” —— 深度解析 AppState 与 NetInfo
前端·react native
Moment6 小时前
从美团全栈化看 AI 冲击:前端转全栈,是自救还是必然 🤔🤔🤔
前端·后端·面试
天问一6 小时前
使用 Vue Router 进行路由定制和调用的示例
前端·javascript·vue.js
韩立学长8 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js
优弧8 小时前
离开舒适区100天,我后悔了吗?
前端·后端·面试
胡gh8 小时前
css的臂膀,前端动效的利器,还是布局的“隐形陷阱”?
前端·css·html
灵感菇_8 小时前
Flutter Riverpod 完整教程:从入门到实战
前端·flutter·ui·状态管理
用户21411832636028 小时前
紧急修复!Dify CVE-2025-55182 高危漏洞,手把手教你升级避坑
前端