GO语言篇之WebAssembly

GO语言篇之WebAssembly

WebAssembly是一种高效的二进制编码方式,可以在现代浏览器中以接近原生的性能运行

GO语言支持WebAssembly(简称Wasm)编译目标,通过使用GO语言编写Wasm,将GO程序转化为可以在现代浏览器中运行的Web应用程序

  1. 我使用的编辑器是vscode,需要在项目的根目录下新建.vscode/settings.json

.vscode/settings.json

json 复制代码
{
    "go.toolsEnvVars": {
        "GOARCH": "wasm",
        "GOOS": "js"
    },
    "go.testEnvVars": {
        "GOARCH": "wasm",
        "GOOS": "js"
    },
    "go.installDependenciesWhenBuilding": false
}
  1. 编写GO代码
go 复制代码
package main

import "syscall/js"

func main() {
    //获取全局对象
    global:=js.Global()
    //获取alert函数
    alert:=global.Get("alert")
    //调用alert函数
    alert.Invoke("Hello WebAssembly")
}
  1. 编译成wasm
sh 复制代码
GOOS=js GOARCH=wasm go build -o go.wasm
  1. 拷贝js胶水文件
sh 复制代码
cp "$(go env GOROOT)/misc/wasm/wasm_exec.js" .
  1. 编写html文件
html 复制代码
<html>
    <script src="wasm_exec.js"></script>
    <script>
        const go = new Go();
        WebAssembly.instantiateStreaming(fetch("go.wasm"), go.importObject).then((result) => go.run(result.instance));
    </script>
</html>
  1. 启动web服务
sh 复制代码
# 安装全局的serve
npm i -g serve
# 启动web服务加载当前页面
serve
  1. 浏览器访问http://localhost:3000,不出意外,此时你的浏览器已经弹出Hello WebAssembly的提示了

总体来说,GO语言编写WebAssembly还是比较简单的

相关推荐
牛了爷爷3 分钟前
php伪协议
android·开发语言·php
CSUC12 分钟前
【开发语言】悬空指针问题
开发语言
GOTXX26 分钟前
【Qt】QWidget 核⼼属性详解
开发语言·前端·c++·qt·机器学习·ai·widget
꧁坚持很酷꧂1 小时前
Qt实现文件传输服务器端(图文详解+代码详细注释)
开发语言·数据库·qt
Bug-Free生活1 小时前
Go语言入门到入土——一、安装和Hello World
开发语言·后端·golang
zhuyasen1 小时前
与AI深度融合的Go开发框架sponge,解决使用cursor、trae等AI辅助编程工具开发项目时的部分痛点
人工智能·低代码·golang
PHASELESS4111 小时前
Java堆结构深度解析:原理、实现与应用全指南
java·开发语言·数据结构
DXM05211 小时前
牟乃夏《ArcGIS Engine地理信息系统开发教程》学习笔记2
开发语言·javascript·笔记·学习·arcgis·ae
啥都鼓捣的小yao2 小时前
实战5:Python使用循环神经网络生成诗歌
开发语言·人工智能·python·rnn·深度学习