JS WebAssembly

🌙
手机阅读
本文目录结构

WebAssemblyJavaScript 对象是所有 WebAssembly 相关功能的命名空间。

和大多数全局对象不一样,WebAssembly 不是一个构造函数(它不是一个函数对象)。它类似于 Math 对象或者 Intl 对象,Math 对象也是一个命名空间对象,用于保存数学常量和函数;Intl 则是用于国际化和其他语言相关函数的命名空间对象。

描述

WebAssembly 对象主要用于:

  • 使用 WebAssembly.instantiate() 函数加载 WebAssembly 代码。
  • 通过 WebAssembly.Memory()/WebAssembly.Table() 构造函数创建新的内存和表实例。
  • 由 WebAssembly.CompileError()/WebAssembly.LinkError()/WebAssembly.RuntimeError() 构造函数来提供 WebAssembly 中的错误信息。

方法

WebAssembly.instantiate()

用于编译和实例化 WebAssembly 代码的主 API,返回一个 Module 和它的第一个实例。

WebAssembly.instantiateStreaming()

直接从流式底层源编译和实例化 WebAssembly 模块,同时返回 Module 及其第一个实例。

WebAssembly.compile()

把 WebAssembly 二进制代码编译为一个 WebAssembly.Module ,不进行实例化。

WebAssembly.compileStreaming()

直接从流式底层源代码编译 WebAssembly.Module ,将实例化作为一个单独的步骤。

WebAssembly.validate()

校验 WebAssembly 二进制代码的类型数组是否合法,合法则返回 true ,否则返回 false 。

构造器

WebAssembly.Module()

创建一个新的 WebAssembly 模块对象。

WebAssembly.Instance()

创建一个新的 WebAssembly 实例对象。

WebAssembly.Memory()

创建一个新的 WebAssembly 内存对象。

WebAssembly.Table()

创建一个新的 WebAssembly 表格对象。

WebAssembly.CompileError()

创建一个新的 WebAssembly 编译错误对象。

WebAssembly.LinkError()

创建一个新的 WebAssembly 链接错误对象。

WebAssembly.RuntimeError()

创建一个新的 WebAssembly 运行时错误对象。

示例

通过 fetch 方法获取了 WebAssembly 字节码后,我们通过 WebAssembly.instantiate() 方法对模块进行编译和实例化,在这过程中将一个 JavaScript 函数导入 WebAssembly 模块。这个 promise 实例解析成一个对象 (result),result 包含编译了的 Module 和 Instance 对象。接下来我们调用一个 Instance 导出的 WebAssembly 方法。

  1. var importObject = {
  2. imports: {
  3. imported_func: function(arg) {
  4. console.log(arg);
  5. }
  6. }
  7. };
  8. fetch('simple.wasm').then(response =>
  9. response.arrayBuffer()
  10. ).then(bytes =>
  11. WebAssembly.instantiate(bytes, importObject)
  12. ).then(result =>
  13. result.instance.exports.exported_func()
  14. );

注意:有关使用了我们 fetchAndInstantiate() 库函数的示例,请查看 Github 上的 index.html (或者查看在线示例) 。

规范

Specification Status Comment
WebAssembly JavaScript Interface WebAssembly Working Draft 初始草案定义

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了