Go WASM:如何在 Go 中访问 DOM API?

简介: Go WASM:如何在 Go 中访问 DOM API?

在上一篇文章中,我们讲解了如何通过 JavaScript 调用 Go 编写的函数。

如何通过 JavaScript 运行用 Go 编写的 WebAssembly 模块?

这一篇文章主要介绍如何在 Go 中访问 DOM API。

文章中的代码是使用上篇文章中的代码作为基础进行开发的,如果读不懂可以去看一下上一篇文章。


访问 DOM API


我会带大家做一个小案例,这里案例会使用 go 的 crypto/rand 库生成 0-10 万之间的真随机数,并将它放置到 p 标签中输入到页面上。

首先实现一个 myRand 函数,用来生成随机数。


func myRand() (*big.Int, error) {
  n, err := rand.Int(rand.Reader, big.NewInt(100000))
  return n, err
}

然后实现包裹函数。


func randWrapper() js.Func {
  return js.FuncOf(func(this js.Value, args []js.Value) interface{} {
    jsDoc := js.Global().Get("document")
    if !jsDoc.Truthy() {
      return "document is not defined"
    }
    containerEl := jsDoc.Call("getElementById", "rand-container")
    if !containerEl.Truthy() {
      return "rand-container is not find"
    }
    p := jsDoc.Call("createElement", "p")
    n, err := myRand()
    if err != nil {
      return "unable to generate random number"
    }
    p.Set("innerText", n.Text(10))
    containerEl.Call("append", p)
    return nil
  })
}

包裹函数中的代码主要就是在 Go 中访问 DOM API 的代码,我在这里给大家解释一下。

  • js.Global():该方法的返回值对应的是 JavaScript 的全局对象,也就是浏览器的 window 对象。
  • obj.Get("prop"):obj 代表 JavaScript 中的某个对象,Get 方法可以访问它的 key。就像是 JavaScript 中的 obj.prop。
  • obj.Truthy():该方法和 obj == true 类似,用来判断是否为 nil。
  • obj.Call("method"):该方法用来调用某个对象身上的方法,类似于 JavaScript 中的 obj.method()。我们也可以在后面传递其他参数,作为实际被调用方法的参数。
  • obj.Set("prop", value):obj 代表 JavaScript 中的某个对象,Set 方法可以设置它的属性。就像是 JavaScript 中的 obj.prop = value。值得一提的是,如果想获取或者设置全局变量,都可以通过 jsGlobal().Get/jsGlobal().Set 来操作。

解释完,上面的代码就不难理解了。

我们首先获取 document 对象,然后再去获取一个 id 为 rand-container 的元素。

再去创建一个 p 元素,调用 rand 方法获取随机数,把随机数设置为 p 的内容。

最后把 p 添加到 rand-container 元素中。

实现好这两个函数后,在 main 方法中将这个方法加入到全局对象中。


js.Global().Set("addRand", randWrapper())

然后将代码编译为 wasm 模块。

来到 index.html 中,添加两个元素。


<div id="rand-container"></div>
<button onclick="addRand()">add rand</button>

启动服务器。


go run main.go

来到浏览器中看一下效果。

https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/504c114d14204e1b9a145eaa35f52e8f~tplv-k3u1fbpfcp-zoom-in-crop-mark:4536:0:0:0.awebp

大功告成!



相关文章
|
8天前
|
API 数据安全/隐私保护 UED
探索鸿蒙的蓝牙A2DP与访问API:从学习到实现的开发之旅
在掌握了鸿蒙系统的开发基础后,我挑战了蓝牙功能的开发。通过Bluetooth A2DP和Access API,实现了蓝牙音频流传输、设备连接和权限管理。具体步骤包括:理解API作用、配置环境与权限、扫描并连接设备、实现音频流控制及动态切换设备。最终,我构建了一个简单的蓝牙音频播放器,具备设备扫描、连接、音频播放与停止、切换输出设备等功能。这次开发让我对蓝牙技术有了更深的理解,也为未来的复杂项目打下了坚实的基础。
96 58
探索鸿蒙的蓝牙A2DP与访问API:从学习到实现的开发之旅
|
5月前
|
缓存 弹性计算 API
用 Go 快速开发一个 RESTful API 服务
用 Go 快速开发一个 RESTful API 服务
|
2月前
|
负载均衡 数据可视化 API
像素流送api ue多人访问需要什么显卡服务器
本文总结了关于像素流送技术的五大常见问题,包括是否支持Unity模型推流、UE多人访问的最大并发数、所需服务器配置、稳定性问题及API支持情况,旨在帮助开发者更好地理解和应用这一技术。
59 1
|
2月前
|
API
如何申请微店的API访问权限?
申请微店API访问权限需先注册账号并完成实名认证,随后提交开发申请,学习API接口,实现功能和数据传输,申请授权获取API Key,测试接口,最后正式上线并持续维护优化。
|
3月前
|
编解码 中间件 API
API实现跨平台访问的方式
【10月更文挑战第16天】API实现跨平台访问的方式
58 2
|
2月前
|
Web App开发 API Windows
取接口访问者信息[IP,浏览器,操作系统]免费API接口教程
此API用于获取访问者的IP地址、浏览器和操作系统信息,支持70多种浏览器和操作系统。通过POST或GET请求至`https://cn.apihz.cn/api/ip/getapi.php`,需提供用户ID和KEY。返回结果包括状态码、消息、IP、浏览器和操作系统信息。示例:{&quot;code&quot;:200,&quot;ip&quot;:&quot;175.154.88.178&quot;,&quot;browser&quot;:&quot;Chrome&quot;,&quot;os&quot;:&quot;Windows 10&quot;}。详情见官网文档。
|
3月前
|
中间件 Go API
使用Go语言构建高性能RESTful API
在现代软件开发中,RESTful API因其简洁和高效而成为构建网络服务的首选。Go语言以其并发处理能力和高性能著称,是开发RESTful API的理想选择。本文将介绍如何使用Go语言构建RESTful API,包括基础的路由设置、中间件的使用、数据验证、错误处理以及性能优化。通过实际代码示例,我们将展示Go语言在API开发中的强大功能和灵活性。
|
3月前
|
Kubernetes 安全 Cloud Native
云上攻防-云原生篇&K8s安全-Kubelet未授权访问、API Server未授权访问
本文介绍了云原生环境下Kubernetes集群的安全问题及攻击方法。首先概述了云环境下的新型攻击路径,如通过虚拟机攻击云管理平台、容器逃逸控制宿主机等。接着详细解释了Kubernetes集群架构,并列举了常见组件的默认端口及其安全隐患。文章通过具体案例演示了API Server 8080和6443端口未授权访问的攻击过程,以及Kubelet 10250端口未授权访问的利用方法,展示了如何通过这些漏洞实现权限提升和横向渗透。
267 0
云上攻防-云原生篇&K8s安全-Kubelet未授权访问、API Server未授权访问
|
4月前
|
JSON Go API
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
|
4月前
|
API iOS开发 开发者
Snapchat API 访问:Objective-C 实现示例
Snapchat API 访问:Objective-C 实现示例