探索txiki.js——轻量级JavaScript运行时的奥秘
项目简介
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:assert
tjs:ffi
tjs:getopts
tjs:hashing
tjs:ipaddr
tjs:path
tjs:sqlite
tjs: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和其他优秀贡献者共同努力的结果。带上你的创意,一起加入这个充满活力的开发社区吧!
[]