如何使用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://ybzwz.com/article/jjeied.html