開始使用 Kotlin/Wasm 與 WASI
本教學示範如何使用 WebAssembly System Interface (WASI) 在各種 WebAssembly 虛擬機上執行簡單的 Kotlin/Wasm 應用程式。
您可以找到在 Node.js、Deno 以及 WasmEdge 虛擬機上執行的應用程式範例。輸出結果是一個使用標準 WASI API 的簡單應用程式。
目前 Kotlin/Wasm 支援 WASI 0.1,也稱為 Preview 1。對 WASI 0.2 的支援預計在未來的版本中提供。追蹤此 YouTrack 問題以獲取關於 WASI 0.2 支援的更新資訊。
wasmWasi 目標 預設使用新的例外處理提案,確保與現代 WebAssembly 執行環境有更好的相容性。
Kotlin/Wasm 工具鏈開箱即提供 Node.js 任務 (
wasmWasiNode*)。專案中的其他任務變體,例如使用 Deno 或 WasmEdge 的任務,則作為自訂任務包含在內。
開始之前
下載並安裝最新版本的 IntelliJ IDEA。
透過在 IntelliJ IDEA 中選擇 File | New | Project from Version Control 來複製 Kotlin/Wasm WASI 範本存儲庫。
您也可以從命令列複製:
bashgit clone [email protected]:Kotlin/kotlin-wasm-wasi-template.git
執行應用程式
透過選擇 View | Tool Windows | Gradle 來開啟 Gradle 工具視窗。
當專案載入後,您可以在 Gradle 工具視窗中的 kotlin-wasm-wasi-example 下找到 Gradle 任務。
您至少需要 Java 11 作為您的 Gradle JVM,任務才能成功載入。
從 kotlin-wasm-wasi-example | Tasks | kotlin node 中,選擇並執行下列其中一個 Gradle 任務:
wasmWasiNodeRun:在 Node.js 中執行應用程式。
wasmWasiDenoRun:在 Deno 中執行應用程式。
wasmWasiWasmEdgeRun:在 WasmEdge 中執行應用程式。
在 Windows 平台上使用 Deno 時,請確保已安裝
deno.exe。更多資訊請參閱 Deno 的安裝文件。

或者,在終端中從 kotlin-wasm-wasi-template 根目錄執行下列其中一個指令:
在 Node.js 中執行應用程式:
bash./gradlew wasmWasiNodeRun在 Deno 中執行應用程式:
bash./gradlew wasmWasiDenoRun在 WasmEdge 中執行應用程式:
bash./gradlew wasmWasiWasmEdgeRun
當您的應用程式組建成功時,終端將顯示一條訊息:

測試應用程式
您也可以測試 Kotlin/Wasm 應用程式在各個虛擬機上是否正常運作。
在 Gradle 工具視窗中,從 kotlin-wasm-wasi-example | Tasks | verification 執行下列其中一個 Gradle 任務:
- wasmWasiNodeTest:在 Node.js 中測試應用程式。
- wasmWasiDenoTest:在 Deno 中測試應用程式。
- wasmWasiWasmEdgeTest:在 WasmEdge 中測試應用程式。

或者,在終端中從 kotlin-wasm-wasi-template 根目錄執行下列其中一個指令:
在 Node.js 中測試應用程式:
bash./gradlew wasmWasiNodeTest在 Deno 中測試應用程式:
bash./gradlew wasmWasiDenoTest在 WasmEdge 中測試應用程式:
bash./gradlew wasmWasiWasmEdgeTest
終端將顯示測試結果:

下一步?
在 Kotlin Slack 加入 Kotlin/Wasm 社群:
嘗試更多 Kotlin/Wasm 範例:
