Project Icon

jiti

Node.js 实时编译工具支持 TypeScript 和 ESM

jiti 是一款 Node.js 实时编译工具,支持 TypeScript 和 ESM 语法。它提供 CJS 和 ESM 互操作性、同步异步 API 以及 ESM 加载器。该工具体积小、无依赖,通过智能语法检测和文件系统缓存优化性能。jiti 已在 Nuxt、Tailwindcss 等项目中应用,月下载量超 5800 万次。

jiti

npm版本 npm下载量 包大小

为Node.js提供即时Typescript和ESM支持。

[!重要] 这是jiti v2的开发分支。查看jiti/v1获取最新稳定版文档,以及unjs/jiti#174了解v2路线图。

✅ 特性

  • 无缝支持Typescript和ESM语法
  • ESM和CommonJS之间无缝互操作
  • 同步API替代require()
  • 异步API替代import()
  • 支持ESM加载器
  • 超轻量且零依赖
  • 智能语法检测以避免额外转换
  • 集成Node.js原生require缓存
  • 文件系统转译并使用硬盘缓存
  • 自定义解析别名

🌟 使用者

💡 使用方法

命令行

您可以使用jiti CLI快速运行任何带有Typescript和原生ESM支持的脚本!

npx jiti ./index.ts

# 或

jiti ./index.ts

编程方式

// --- 初始化 ---

// ESM
import { createJiti } from "jiti";
const jiti = createJiti(import.meta.url);

// CommonJS
const { createJiti } = require("jiti");
const jiti = createJiti(__filename);

// --- ESM兼容API ---

// jiti.import()类似于import(),但支持Typescript
await jiti.import("./path/to/file.ts");

// jiti.esmResolve()类似于import.meta.resolve(),但有额外功能
const resolvedPath = jiti.esmResolve("./src");

// --- CJS兼容API ---

// jiti()类似于require(),但支持Typescript和(非异步)ESM
jiti("./path/to/file.ts");

// jiti.resolve()类似于require.resolve(),但有额外功能
const resolvedPath = jiti.resolve("./src");

您也可以将选项作为第二个参数传递:

const jiti = createJiti(import.meta.url, { debug: true });

注册全局ESM加载器

您可以使用全局钩子全局注册jiti。

注意: 这是一种实验性方法,仅在Node.js > 20上测试通过。除非必要,否则我不推荐使用它,请优先选择显式方法。

import "jiti/register";

或:

node --import jiti/register index.ts

⚙️ 选项

debug

  • 类型:Boolean
  • 默认值:false
  • 环境变量:JITI_DEBUG

启用详细日志记录。您可以使用JITI_DEBUG=1 <您的命令>来启用它。

fsCache

  • 类型:Boolean | String
  • 默认值:true
  • 环境变量:JITI_FS_CACHE

文件系统源缓存(默认启用)

默认情况下(当为true时),jiti使用node_modules/.cache/jiti(如果存在)或{TMP_DIR}/jiti

注意: 建议保持此选项启用以获得更好的性能。

moduleCache

  • 类型:String
  • 默认值:true
  • 环境变量:JITI_MODULE_CACHE

运行时模块缓存(默认启用)。

禁用允许编辑代码并多次导入同一模块。

启用时,jiti与Node.js原生CommonJS缓存存储集成。

transform

  • 类型:Function
  • 默认值:Babel(懒加载)

转换函数。更多详情请参见src/babel

sourceMaps

  • 类型:Boolean
  • 默认值:false
  • 环境变量:JITI_SOURCE_MAPS

为转换后的源代码添加内联源映射,以便更好地调试。

interopDefault

  • 类型:Boolean
  • 默认值:false
  • 环境变量:JITI_INTEROP_DEFAULT

在顶层返回模块的.default导出。

alias

  • 类型:Object
  • 默认值:-
  • 环境变量:JITI_ALIAS

用于解析ID的自定义别名映射。

nativeModules

  • 类型:Array
  • 默认值:['typescript']
  • 环境变量:JITI_NATIVE_MODULES

始终使用原生require的模块列表(位于node_modules中)。

transformModules

  • 类型:Array
  • 默认值:[]
  • 环境变量:JITI_TRANSFORM_MODULES

无论语法如何都要转换的模块列表(位于node_modules中)。

experimentalBun

  • 类型:Boolean
  • 默认值:如果存在process.versions.bun(Bun运行时)则启用
  • 环境变量:JITI_EXPERIMENTAL_BUN

启用实验性的原生Bun支持进行转换。

开发

  • 克隆此仓库
  • 使用corepack enable启用Corepack
  • 使用pnpm install安装依赖
  • 运行pnpm dev
  • 运行pnpm jiti ./test/path/to/file.ts

许可证

根据MIT许可证发布。 由@pi0社区制作 💛

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号