温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用golang生成wasm文件并在浏览器上执行

发布时间:2022-03-04 14:01:41 来源:亿速云 阅读:1371 作者:iii 栏目:web开发

这篇文章主要讲解了“如何使用golang生成wasm文件并在浏览器上执行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用golang生成wasm文件并在浏览器上执行”吧!

webassembly是什么?

webassembly是可以支持在web浏览器或者v8等环境下的二进制格式,想具体了解可以查看这个回答

开始

需要先升级go到1.11版本

编写需要编译成wasm文件的go文件

// main.go

package main

func main() {

println("Hello, WebAssembly!")

}

执行build命令

GOARCH=wasm GOOS=js go build -o test.wasm main.go

注意这个是在mac或者linux操作系统下执行的命令,在windows下应该设置环境变量再执行编译命令

$env:GOARCH="wasm";$env:GOOS="js";

go build -o test.wasm main.go

命令执行完后,后生成test.wasm文件,这个就是可以在浏览器上运行的二进制文件

添加其他依赖

复制$(go env GOROOT)/misc/wasm/下的wasm_exec.html和wasm_exec.js两个文件到当前目录

搭建web服务器

// test.go

package main

import (

"flag"

"log"

"net/http"

"strings"

)

var (

listen = flag.String("listen", ":8080", "listen address")

dir    = flag.String("dir", ".", "directory to serve")

)

func main() {

flag.Parse()

log.Printf("listening on %q...", *listen)

log.Fatal(http.ListenAndServe(*listen, http.HandlerFunc(func(resp http.ResponseWriter, req *http.Request) {

if strings.HasSuffix(req.URL.Path, ".wasm") {

resp.Header().Set("content-type", "application/wasm")

}

http.FileServer(http.Dir(*dir)).ServeHTTP(resp, req)

})))

}

运行web服务

go run test.go

测试

在浏览器中打开http://localhost:8080/wasm_exec.html,点击页面中的run按钮,即可看到控制台打印Hello, WebAssembly!

这样我们就已经可以使用go编写一个可以运行在浏览器的程序了

如何使用js

使用go的js库syscall/js

// main.go

package main

import "syscall/js"

func sum(args []js.Value) {

var sum int

for _, val := range args {

sum += val.Int()

}

println(sum)

}

func registerCallbacks() {

js.Global().Set("sum", js.NewCallback(sum))

}

func main() {

c := make(chan struct{}, 0)

println("Hello, WebAssembly!")

registerCallbacks()

<-c

}

重新编译后,刷新页面,点击run按钮,就会为window对象挂载一个sum函数,在控制台可以调用

操作dom

在go中可以获取window对象来达到操作dom的效果,做一个计算器

感谢各位的阅读,以上就是“如何使用golang生成wasm文件并在浏览器上执行”的内容了,经过本文的学习后,相信大家对如何使用golang生成wasm文件并在浏览器上执行这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI