分享更有价值
被信任是一种快乐

如何使用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按钮,即可看到控制台打印H免费云主机、域名ello, 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()

}
重新编译后,刷新页面,点击run按钮,就会为window对象挂载一个sum函数,在控制台可以调用
操作dom
在go中可以获取window对象来达到操作dom的效果,做一个计算器感谢各位的阅读,以上就是“如何使用golang生成wasm文件并在浏览器上执行”的内容了,经过本文的学习后,相信大家对如何使用golang生成wasm文件并在浏览器上执行这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是云技术,小编将为大家推送更多相关知识点的文章,欢迎关注!

相关推荐: jquery如何修改滚动条位置

这篇“jquery如何修改滚动条位置”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“jquery如何修改滚动条位置”文章吧。 修改方法:1、用sc…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册