放弃 tsc+nodemon 使用 tsx 构建Node 环境下 TypeScript + ESM 开发环境搭建指南

article/2025/6/25 14:06:52

放弃 tsc+nodemon 使用 tsx 构建Node 环境下 TypeScript + ESM 开发环境搭建指南

目标

在 node 环境下构建 typescript + esmodule模块 开发环境,这样可以使用 typescript 提供的类型安全和类型提示便利性。

我们要实现下面的效果

  1. 文件目录

    • 在这里插入图片描述
  2. src/index.ts 注意是 esmodule 规范

    • 在这里插入图片描述
  3. 运行效果

    • 在这里插入图片描述

TSX 模块介绍

TSX 模块
TSX 是一个专为现代 Node.js 设计的 TypeScript 运行时,它替代了传统的 ts-node--loader 方案,特别适合在 ESM 环境下使用。

  1. 原生 ESM 支持
    - 完全支持 Node.js 的 ES Modules 规范
    - 无需额外的 --loader--experimental 标志
    - 自动处理 .ts.tsx 文件导入
  2. 高性能
    - 使用 Rust 编写的快速转译器 (基于 SWC)
    - 比传统 ts-node 快 5-20 倍
    - 智能缓存机制减少重复编译
  3. 零配置
    - 自动检测项目中的 tsconfig.json
    - 内置支持 TypeScript 路径映射
    - 自动处理 CommonJS 和 ESM 互操作
  4. 替代nodemon
    - tsx watch 会监视文件变化并自动重新加载

为什么选择 ESM?

ES Modules 是 JavaScript 的官方模块标准,相比传统的 CommonJS (CJS) 具有以下优势:

  • 静态分析能力,便于 tree-shaking
  • 浏览器原生支持
  • 更好的异步加载特性
  • 更清晰的模块语法

环境准备

确保你已安装:

  • Node.js 16+ (推荐 20+ 或最新 LTS 版本)
  • pnpm(推荐) 或者 npm 或 yarn
  • 代码编辑器 (VS Code 推荐)

项目初始化

mkdir ts-esm-project
cd ts-esm-project
pnpm init

安装必要依赖

pnpm install typescript @types/node --save-dev
pnpm install tsx --save-dev

配置 TypeScript

创建 tsconfig.json 文件:

{"compilerOptions": {"target": "ES2022","module": "NodeNext","moduleResolution": "NodeNext","outDir": "./dist","rootDir": "./src","strict": true,"esModuleInterop": true,"skipLibCheck": true,"forceConsistentCasingInFileNames": true,"baseUrl": ".","paths": {"@/*": ["src/*"]}},"include": ["src/**/*"],"exclude": ["node_modules"]
}

关键配置说明:

  • "module": "NodeNext" - 使用 Node.js 的模块系统
  • "moduleResolution": "NodeNext" - 使用 Node.js 的模块解析算法
  • "esModuleInterop": true - 允许与 CommonJS 模块互操作

配置 package.json

修改 package.json

{"type": "module","scripts": {"build": "tsc","start": "node ./dist/index.js","dev": "tsx watch src/index.ts","test": "NODE_OPTIONS='--import tsx' vitest"},"devDependencies": {"tsx": "^4.7.0","typescript": "^5.3.0"}
}

项目结构示例

ts-esm-project/
├── src/
│   ├── index.ts
│   ├── utils/
│   │   └── helper.ts
├── tsconfig.json
├── package.json

示例代码

src/index.ts:

import { readFile } from 'node:fs/promises';
import { helper } from '@/utils/helper';// 文件后缀js ts 或者不加都可以const main = async () => {const content = await readFile('./package.json', { encoding: 'utf-8' });console.log('Package content:', content);helper();
};main().catch(console.error);

src/utils/helper.ts:

export function helper() {console.log('Helper function called');
}

import { helper } from '@/utils/helper';// 文件后缀 js ts 或者不加都可以

开发工作流

  1. 开发模式​:

    npm run dev
    

    tsx watch 会监视文件变化并自动重新加载

  2. 生产构建​:

    npm run build
    

    生成的文件会输出到 dist/ 目录

  3. 运行生产代码​:

    npm start
    

常见问题解决(可能遇到)

1. 文件扩展名问题

ESM 要求导入时必须指定完整扩展名。解决方案:

// 正确
import './utils/index.js' 
// 正确
import './utils/index' 
// 正确
import './utils/index.ts' 
// 错误
import './utils'

2. __dirname 替代方案

ESM 中没有 __dirname,替代方案:

import { dirname } from 'node:path';
import { fileURLToPath } from 'node:url';const __dirname = dirname(fileURLToPath(import.meta.url));

3. 第三方模块兼容性

如果遇到 ESM/CJS 混合问题,可以尝试:

  1. 检查该模块是否有 ESM 版本

  2. 使用动态导入:

    const { default: pkg } = await import('some-package');
    

测试环境配置

推荐使用 Vitest:

npm install vitest --save-dev

vite.config.ts:

import { defineConfig } from 'vitest/config';export default defineConfig({test: {include: ['**/*.test.ts'],globals: true}
});

部署注意事项

  1. 生产环境应该运行编译后的 .js 文件

  2. 确保 package.json 中包含:

    {"type": "module","engines": {"node": ">=18.0.0"}
    }
    

总结

666666666666666666666666


http://www.hkcw.cn/article/VEdNXRwSxr.shtml

相关文章

Geogebra中导出3D Graphics窗口

导出没有特别的自定义设置,默认的第一个窗口是Graphics, 还有Graphics 2和3D Graphics ,优先顺序依次递减。如果要想导出的是3D Graphics, 需要确保关闭另外两个窗口。 这个是视频转换: 下面是直接导出: 带渲染效果的,其实是Al…

LeetCode 高频 SQL 50 题(基础版) 之 【高级查询和连接】· 上

题目:1731. 每位经理的下属员工数量 题解: select employee_id,name,reports_count,average_age from Employees t1,(select reports_to,count(*) reports_count,round(avg(age)) average_agefrom Employeeswhere reports_to is not nullgroup by repor…

韩国大选三强对决 李在明领跑 民众意愿强烈

韩国第21届总统选举于6月3日举行,预计4日凌晨揭晓结果。当选总统将立即就职,任期5年。当地时间2025年5月30日,韩国京畿道果川市中央选举管理委员会选举综合情况室的工作人员正在检查境内提前投票箱的存放地点监控视频。从去年12月3日的风波到今年4月4日前总统尹锡悦被罢免,…

48岁网红“大刚”疑酒精中毒离世 民间艺人突陨落

6月1日,短视频账号“大刚演艺传媒”发布讣告,宣布景旭刚因病于当天上午不幸离世,享年48岁。定于6月4日出殡。许多网友在评论区对景旭刚的离世表达了哀思,并称赞他多才多艺。次日,景旭刚的妻子确认了这一消息,称丈夫因饮酒过量导致酒精中毒去世。景旭刚的儿子也在朋友圈发…

泽连斯基:蛛网行动准备超过一年半 精心策划载入史册

乌克兰在与俄罗斯举行第二轮谈判前夕,发动了“蛛网”行动,袭击了俄罗斯多地。据报道,行动中的无人机通过货柜车偷运进入俄方领土。乌克兰总统泽连斯基表示,这次行动经过了一年半以上的准备,并且精心策划。他称赞此次行动堪称精彩,认为乌军的行动无疑将载入史册。乌克兰安…

女子被逼复婚又屡遭家暴,7岁儿子哭求爸爸别打了!

女子被逼复婚又屡遭家暴。重庆市的谭女士在自家水果店中,公然遭受了丈夫的家庭暴力,导致身上多处受伤。谭女士表示,她一定要站出来,用实际行动,坚决向家庭暴力说“不”!重庆的谭女士告诉记者她又被丈夫家暴打成闭合型颅脑损伤,他打她的原因让人不可思议,竟是因为她带孩…

【深度学习】实验四 卷积神经网络CNN

实验四 卷积神经网络CNN 一、实验学时: 2学时 二、实验目的 掌握卷积神经网络CNN的基本结构;掌握数据预处理、模型构建、训练与调参;探索CNN在MNIST数据集中的性能表现; 三、实验内容 实现深度神经网络CNN。 四、主要实验步…

通俗理解“高内聚,低耦合”

在软件开发中,良好的架构设计能够大幅降低系统的复杂度,提高代码的可维护性。而“高内聚,低耦合”正是指导我们如何合理组织代码的核心原则之一。本文将从通俗的角度解释这一概念,并结合实际案例说明其重要性。 一,高…

Unity + HybirdCLR热更新 入门篇

官方文档 HybridCLR | HybridCLRhttps://hybridclr.doc.code-philosophy.com/docs/intro 什么是HybirdCLR? HybridCLR(原名 huatuo)是一个专为 Unity 项目设计的C#热更新解决方案,它通过扩展 IL2CPP 运行时,使其支持动态加载和…

Python基础:人生重开模拟器(小游戏)

引言 手把手带你速通Python 实现人生重开模拟器(小游戏)的意义:增强对条件语句,循环语句的运用,增加写代码的乐趣。 一、 游戏介绍 网页版的人生重开模拟器: 人生重开模拟器-重来-重启 (aizhancloud.cn) …

【Elasticsearch】ILM(Index Lifecycle Management)策略详解

ILM(Index Lifecycle Management)策略详解 1.什么是 ILM 策略?2.ILM 解决的核心业务问题3.ILM 生命周期阶段3.1 Hot(热阶段)3.2 Warm(温阶段)3.3 Cold(冷阶段)3.4 Delete…

【存储基础】数据存储基础知识

文章目录 1. 概述:数据存储基础知识2. 存储物理介质3. 数据存储的分类3.1按存储架构分类DAS 直连存储SAN 存储区域网络NAS 网络附加存储分布式存储四种架构之间的核心区别 3.2 按数据模型分类块存储文件存储对象存储 4. 数据存储的关键技术方案和核心机制冗余与容错…

【Part 3 Unity VR眼镜端播放器开发与优化】第二节|VR眼镜端的开发适配与交互设计

文章目录 《VR 360全景视频开发》专栏Part 3|Unity VR眼镜端播放器开发与优化第一节|基于Unity的360全景视频播放实现方案第二节|VR眼镜端的开发适配与交互设计一、Unity XR开发环境与设备适配1.1 启用XR Plugin Management1.2 配置OpenXR与平…

小米YU7还有5款颜色即将发布 更多色彩敬请期待

6月1日,小米在5月22日的发布会上公布了YU7的四款颜色:钛金属色、宝石绿、熔岩橙和寒武岩灰。官方透露,除了这四款已发布的颜色外,还有五款新颜色即将推出,每一种都设计得非常经典。回顾之前的小米SU7,在刚推出时就提供了9种颜色选择,涵盖了跑车色系、时尚色系、豪华色系…

老人被甩客执法人员送其回家 温情护送获赠枇杷

日前,重庆交通执法总队轨道交通支队三大队在重庆西站巡查时发现一名老人误乘“黑车”。考虑到她年近九旬行动不便,执法人员开车将其安全护送回家。老人感激地拿出自己种的枇杷送给执法人员以示感谢。5月27日上午,执法人员在巡查过程中发现一辆渝A籍车辆正在下客,随即上前检…

2025最新 MacBook Pro苹果电脑M系列芯片安装zsh教程方法大全

2025最新 MacBook Pro苹果电脑M系列芯片安装zsh教程方法大全 本文面向对 macOS 环境和终端操作尚不熟悉的“小白”用户。我们将从最基础的概念讲起,结合实际操作步骤,帮助你在 2025 年最新 MacBook Pro(搭载苹果 M 系列芯片)的环境…

女子多次上门骚扰邻居 持刀砍门引发恐慌

近日,辽宁大连有网友发布视频称,疑似患有精神疾病的邻居多次持刀上门砍其家门。当事人刘女士向媒体透露,楼下60多岁的邻居自去年10月搬家入住后,就反复上门找事,声称刘女士一家是脑控组织,想要入侵她的大脑。刘女士表示自己是外地人,去年刚搬进来,为方便孩子上学才购买…

遥控器竟牵出10亿元大案 数据篡改揭秘

涉及河南、四川、浙江等16省市,涉案交易金额达10.3亿元的合同诈骗案成功告破。内蒙古自治区鄂尔多斯市杭锦旗警方通过流量计调节流量和篡改数据的方式,将27名犯罪嫌疑人全部抓获。2024年3月,一封匿名举报信揭露了某石油工程有限公司通过更改流量计数据窃取国家能源的行为。杭…

弗朗西斯卡说樊振东加盟像做梦一样 莫大荣耀与期待

6月2日,据外媒报道,队长弗朗西斯卡在接受采访时谈到夺冠以及樊振东加盟表示:“感觉像做梦一样,樊振东加盟是我们莫大的荣耀。”决赛周末俱乐部宣布了轰动消息,奥运冠军兼前世界冠军樊振东将代表球队出战全部三项赛事。对于下赛季谁能击败他们的问题,弗朗西斯卡表示这取决…

董宇辉在陕西汉江赛龙舟夺冠 体验传统民俗乐趣

5月31日,陕西安康第25届汉江龙舟节开幕。当日,龙舟方阵展演,龙舟横渡汉江,抢鸭子、摸鲤鱼等传统环节亮相开幕式,节日氛围浓厚。今年有27支队伍600多名选手参加龙舟竞渡比赛。董宇辉现身安康龙舟文化园,与现场市民、游客热情互动,齐喊端午安康。他和团队成员在汉江边进行…