【免费下载】 探索txiki.js——轻量级JavaScript运行时的奥秘
2026-01-15 16:39:28作者:温艾琴Wonderful

项目简介
txiki.js,一个基于巴斯克语“小”的含义命名的微型JavaScript运行时,以其小巧而强大著称。它利用了QuickJS-ng作为JavaScript引擎,并依赖于libuv库来处理平台层任务。这个项目旨在实现最新ECMAScript标准并提供多种Web平台特性。
观看以下视频,深入了解txiki.js是如何构建的:
快速上手
要开始使用txiki.js,请首先按照构建部分的说明进行编译。
$ ./build/tjs eval "console.log('hello world')"
hello world
$
你可以通过tjs run命令运行脚本:
$ ./build/tjs run examples/hello_world.js
hello world
$
了解更多选项,只需执行:
$ ./build/tjs --help
对TypeScript的支持,可以查看@txikijs/types包。
特性概览
txiki.js支持ES2020规范以及一些更高级别的特性,如顶级await。此外,它还提供了许多Web平台API。
Web平台API
- alert, confirm, prompt(异步)
- Console
- Crypto(非微妙支持)
- Encoding API
- EventTarget
- fetch
- [JSON 模块导入]
- Performance
- setTimeout, setInterval
- Storage API
- Streams API
- URL
- URLPattern
- URLSearchParams
- WebAssembly(不支持表、全局变量和内存)
- WebSocket
- Web Workers API
运行时特性
- TCP和UDP套接字
- Unix套接字/命名管道
- 信号处理
- 文件操作
- 子进程
- DNS(getaddrinfo)
- WASI
- 多种实用函数
查看完整的[API文档]以获取更多详细信息。
其他附加功能包括直接从HTTP(S) URL导入,导入JSON文件,大浮点数和大数扩展,内置测试运行器。
标准库
txiki.js的标准库包含以下几个模块:
tjs:asserttjs:ffitjs:getoptstjs:hashingtjs:ipaddrtjs:pathtjs:sqlitetjs:uuid
支持的平台
- GNU/Linux
- macOS
- Windows(β测试版)
- 其他Unix系统(请测试!)
构建过程
需安装CMake。
如果你没有递归地克隆此仓库,请确保初始化所有子模块(包括libffi、libuv和wasm3):
git submodule update --init
GNU/Linux
安装依赖项(libcurl4-openssl-dev,build-essential,cmake,makeinfo,autoreconf,libtool):
# 在Debian / Ubuntu上
sudo apt install libcurl4-openssl-dev build-essential cmake autoconf texinfo libtool
macOS
安装依赖项(cmake,autoconf):
brew install cmake autoconf automake libtool texinfo
Unix系统
# 获取代码
git clone --recursive https://github.com/saghul/txiki.js --shallow-submodules && cd txiki.js
# 编译源码
make
# 运行REPL
./build/tjs
Windows(β测试版)
需求
首先确保已安装MSYS2。目前仅测试了mingw64和clang64环境。
安装所需依赖:
pacman -S git make pactoys
pacboy -S curl-winssl:p toolchain:p cmake:p ninja:p
构建
在MinGW64或clang64 shell中运行以下命令:
make
版本控制
txiki.js当前采用[日历版本控制],形式为YY.MM.MICRO。
结语
txiki.js是saghul和其他优秀贡献者共同努力的结果。带上你的创意,一起加入这个充满活力的开发社区吧!
[]
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677
