在 Go WASM 导出中公开函数名称
将 Go 代码编译到 WASM 时,您可能会遇到想要保留函数名称的情况在生成的 .wasm 文件中。默认情况下,标准 Go 编译器在编译过程中不会导出函数名称。
要实现函数名称可导出性,您有两个选择:
1。使用 TinyGo
TinyGo,一个嵌入式且面向 WASM 的 Go 编译器,通过 //export 或 //go:export 注释指令提供对导出函数的支持。这是一个示例:
<code class="Go">//export multiply func multiply(x, y int) int { return x * y; }</code>
使用 TinyGo 进行编译时(例如,tinygo build -o wasm.wasm -target wasm ./main.go),乘法函数将在生成的 WASM 文件中公开。
2。使用标准 Go 编译器(实验性)
标准 Go 编译器目前正在致力于引入类似于 TinyGo 的 //export 指令的功能。不过,该功能仍在开发中。或者,您可以使用 js.Global().Set(...) 函数将 Go 函数设置为 JS 全局命名空间的属性。
示例:
<code class="Go">import ( "github.com/gopherjs/gopherjs/js" ) func main() { js.Global().Set("multiply", multiply) } func multiply(x, y int) int { return x * y; }</code>
这种方法允许您在全局 JavaScript 命名空间中公开乘法函数,从而可以在 WASM 代码中访问它。
以上是如何在 Go WASM 中导出函数名称?的详细内容。更多信息请关注PHP中文网其他相关文章!