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

这篇文章主要讲解了“如何使用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文件并在浏览器上执行这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!


新闻名称:如何使用golang生成wasm文件并在浏览器上执行
标题路径:http://scyanting.com/article/jjeied.html