WebAssembly.Table.prototype.set()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since October 2017.
Die set()
Prototyp-Methode des WebAssembly.Table
-Objekts ändert eine in einem bestimmten Index gespeicherte Referenz in einen anderen Wert.
Syntax
set(index, value)
Parameter
index
-
Der Index der Funktionsreferenz, die Sie ändern möchten.
value
-
Der Wert, auf den Sie die Referenz ändern möchten. Dies muss ein Wert des Elementtyps der Tabelle sein. Abhängig vom Typ kann es eine exportierte WebAssembly-Funktion, ein JavaScript-Wrapper für eine zugrunde liegende Wasm-Funktion oder eine Host-Referenz sein.
Rückgabewert
Keiner (undefined
).
Ausnahmen
- Wenn
index
größer oder gleichTable.prototype.length
ist, wird einRangeError
ausgelöst. - Wenn
value
nicht vom Elementtyp der Tabelle ist, wird einTypeError
ausgelöst.
Beispiele
Verwendung von Table.set
Das folgende Beispiel (siehe table2.html Quellcode und Live-Version) erstellt eine neue WebAssembly-Tabelle mit einer anfänglichen Größe von zwei Referenzen. Anschließend geben wir die Tabellenlänge und die Inhalte der beiden Indizes aus (abgerufen über Table.prototype.get()
), um zu zeigen, dass die Länge zwei beträgt und die Indizes derzeit keine Funktionsreferenzen enthalten (sie geben aktuell null
zurück).
const tbl = new WebAssembly.Table({ initial: 2, element: "anyfunc" });
console.log(tbl.length);
console.log(tbl.get(0));
console.log(tbl.get(1));
Wir erstellen dann ein Importobjekt, das eine Referenz auf die Tabelle enthält:
const importObj = {
js: { tbl },
};
Abschließend laden und instanziieren wir ein Wasm-Modul (table2.wasm) mit WebAssembly.instantiateStreaming()
, drucken die Tabellenlänge und rufen die zwei Funktionsreferenzen auf, die jetzt in der Tabelle gespeichert sind. Das table2.wasm
-Modul fügt der Tabelle zwei Funktionsreferenzen hinzu, die beide einen einfachen Wert ausgeben (siehe Textdarstellung):
WebAssembly.instantiateStreaming(fetch("table2.wasm"), importObject).then(
(obj) => {
console.log(tbl.length);
console.log(tbl.get(0)());
console.log(tbl.get(1)());
},
);
Beachten Sie, dass Sie am Ende des Zugriffsoperators einen zweiten Funktionsaufrufsoperator einfügen müssen, um die referenzierte Funktion tatsächlich aufzurufen und den darin gespeicherten Wert zu protokollieren (z. B. get(0)()
anstelle von get(0)
).
Dieses Beispiel zeigt, dass wir die Tabelle von JavaScript aus erstellen und darauf zugreifen, aber dieselbe Tabelle ist auch innerhalb der Wasm-Instanz sichtbar und aufrufbar.
Spezifikationen
Specification |
---|
WebAssembly JavaScript Interface # dom-table-set |