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

大功告成!



相关文章
|
3月前
|
JSON API 开发工具
【Azure 应用服务】调用Azure REST API来获取 App Service的访问限制信息(Access Restrictions)以及修改
【Azure 应用服务】调用Azure REST API来获取 App Service的访问限制信息(Access Restrictions)以及修改
|
3月前
|
缓存 弹性计算 API
用 Go 快速开发一个 RESTful API 服务
用 Go 快速开发一个 RESTful API 服务
|
1月前
|
编解码 中间件 API
API实现跨平台访问的方式
【10月更文挑战第16天】API实现跨平台访问的方式
47 2
|
1月前
|
中间件 Go API
使用Go语言构建高性能RESTful API
在现代软件开发中,RESTful API因其简洁和高效而成为构建网络服务的首选。Go语言以其并发处理能力和高性能著称,是开发RESTful API的理想选择。本文将介绍如何使用Go语言构建RESTful API,包括基础的路由设置、中间件的使用、数据验证、错误处理以及性能优化。通过实际代码示例,我们将展示Go语言在API开发中的强大功能和灵活性。
|
1月前
|
Kubernetes 安全 Cloud Native
云上攻防-云原生篇&K8s安全-Kubelet未授权访问、API Server未授权访问
本文介绍了云原生环境下Kubernetes集群的安全问题及攻击方法。首先概述了云环境下的新型攻击路径,如通过虚拟机攻击云管理平台、容器逃逸控制宿主机等。接着详细解释了Kubernetes集群架构,并列举了常见组件的默认端口及其安全隐患。文章通过具体案例演示了API Server 8080和6443端口未授权访问的攻击过程,以及Kubelet 10250端口未授权访问的利用方法,展示了如何通过这些漏洞实现权限提升和横向渗透。
154 0
云上攻防-云原生篇&K8s安全-Kubelet未授权访问、API Server未授权访问
|
2月前
|
JSON Go API
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
使用Go语言和Gin框架构建RESTful API:GET与POST请求示例
|
2月前
|
API iOS开发 开发者
Snapchat API 访问:Objective-C 实现示例
Snapchat API 访问:Objective-C 实现示例
|
2月前
|
XML 缓存 JavaScript
提升对前端的认知,不得不了解Web API的DOM和BOM
该文章强调了在前端开发中理解和掌握DOM(文档对象模型)和BOM(浏览器对象模型)的重要性,并介绍了它们的相关操作和应用。
提升对前端的认知,不得不了解Web API的DOM和BOM
|
2月前
|
Go API 开发者
深入探讨:使用Go语言构建高性能RESTful API服务
在本文中,我们将探索Go语言在构建高效、可靠的RESTful API服务中的独特优势。通过实际案例分析,我们将展示Go如何通过其并发模型、简洁的语法和内置的http包,成为现代后端服务开发的有力工具。
|
3月前
|
存储 算法 Java
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据
Go 通过 Map/Filter/ForEach 等流式 API 高效处理数据