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还是比较简单的

相关推荐
北冥湖畔的燕雀2 小时前
C++泛型编程(函数模板以及类模板)
开发语言·c++
QX_hao3 小时前
【Go】--map和struct数据类型
开发语言·后端·golang
你好,我叫C小白3 小时前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
Evand J5 小时前
【MATLAB例程】基于USBL和DVL的线性回归误差补偿,对USBL和DVL导航数据进行相互补偿,提高定位精度,附代码下载链接
开发语言·matlab·线性回归·水下定位·usbl·dvl
爱喝白开水a6 小时前
LangChain 基础系列之 Prompt 工程详解:从设计原理到实战模板_langchain prompt
开发语言·数据库·人工智能·python·langchain·prompt·知识图谱
Neverfadeaway6 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
武子康6 小时前
Java-152 深入浅出 MongoDB 索引详解 从 MongoDB B-树 到 MySQL B+树 索引机制、数据结构与应用场景的全面对比分析
java·开发语言·数据库·sql·mongodb·性能优化·nosql
杰克尼6 小时前
JavaWeb_p165部门管理
java·开发语言·前端
一成码农6 小时前
JavaSE面向对象(下)
java·开发语言
偶尔的鼠标人7 小时前
Avalonia DataGrid 控件的LostFocus事件会多次触发
开发语言·c#