如何使用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文件并在浏览器上执行
网页URL:http://bzwzjz.com/article/jjeied.html

其他资讯

Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 营销型网站建设 网站设计 成都网站制作 成都网站设计公司 手机网站建设 商城网站建设 H5网站制作 网站设计制作 网站建设费用 手机网站制作 成都商城网站建设 成都网站建设 成都网站建设 成都品牌网站设计 成都企业网站制作 营销网站建设 企业网站设计 app网站建设 定制级高端网站建设 重庆网站制作 重庆企业网站建设 网站建设改版