WebAssembly.Global
对象表示一个全局变量实例, 可以被JavaScript 和importable/exportable 访问 ,跨越一个或多个WebAssembly.Module
实例. 他允许被多个modules动态连接.
var myGlobal = new WebAssembly.Global(descriptor, value);
GlobalDescriptor
包含2个属性的表:
value
: A USVString
表示全局变量的数据类型. 可以是i32
, i64
, f32
, 或 f64
.mutable
: 布尔值决定是否可以修改. 默认是 false
.DefaultValue
algorithm.None.
所有的 Global
实例 继承自 Global()
构造函数 prototype object — 修改会影响 所有 Global
实例.
Global.prototype.constructor
WebAssembly.Global()
constructor.Global.prototype[@@toStringTag]
Global.prototype.value
Global.prototype.valueOf()
以下例子展示了使用 WebAssembly.Global()
构造函数创建一个新的实例. 它定义为可修饰的 类型为i32
, 值为 0.
global的值发生改变, 首先设置Global.value
为42, 然后使用导出函数 incGlobal()
增加为43. 导出函数在 global.wasm
模块中(它将参数的值加一并返回).
const output = document.getElementById('output');
function assertEq(msg, got, expected) {
output.innerHTML += `Testing ${msg}: `;
if (got !== expected)
output.innerHTML += `FAIL!<br>Got: ${got}<br>Expected: ${expected}<br>`;
else
output.innerHTML += `SUCCESS! Got: ${got}<br>`;
}
assertEq("WebAssembly.Global exists", typeof WebAssembly.Global, "function");
const global = new WebAssembly.Global({value:'i32', mutable:true}, 0);
WebAssembly.instantiateStreaming(fetch('global.wasm'), { js: { global } })
.then(({instance}) => {
assertEq("getting initial value from wasm", instance.exports.getGlobal(), 0);
global.value = 42;
assertEq("getting JS-updated value from wasm", instance.exports.getGlobal(), 42);
instance.exports.incGlobal();
assertEq("getting wasm-updated value from JS", global.value, 43);
});
注意: 你可以在running live on GitHub 查看例子; 也可以访问source code.
规格 | 状态 | 解释 |
---|---|---|
WebAssembly JavaScript Interface WebAssembly.Global() |
Working Draft | Initial draft definition. |
Desktop | Mobile | Server | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Global | Chrome Full support 69 | Edge No support No | Firefox Full support 62 | IE No support No | Opera No support No | Safari No support No | WebView Android Full support 69 | Chrome Android Full support 69 | Edge Mobile No support No | Firefox Android Full support 62 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android No support No | nodejs No support No |
value | Chrome Full support 69 | Edge No support No | Firefox Full support 62 | IE No support No | Opera No support No | Safari No support No | WebView Android Full support 69 | Chrome Android Full support 69 | Edge Mobile No support No | Firefox Android Full support 62 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android No support No | nodejs No support No |
valueOf | Chrome Full support 69 | Edge No support No | Firefox Full support 62 | IE No support No | Opera No support No | Safari No support No | WebView Android Full support 69 | Chrome Android Full support 69 | Edge Mobile No support No | Firefox Android Full support 62 | Opera Android No support No | Safari iOS No support No | Samsung Internet Android No support No | nodejs No support No |