WebAssembly.Module()
Baseline
Widely available
*
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis octobre 2017.
* Certaines parties de cette fonctionnalité peuvent bénéficier de prise en charge variables.
Un objet WebAssembly.Module contient du code WebAssembly, sans état et qui a déjà été compilé par le navigateur. Ce code peut être partagé avec des web workers et être instancié à plusieurs reprises.
Constructeur
WebAssembly.Module()-
Crée un nouvel objet
Module.
Propriétés statiques
WebAssembly.Module.customSections()-
Soit un objet
Moduleet une chaîne de caractères, cette méthode renvoie le contenu de l'ensemble des sections spécifiques du module avec le nom correspondant à la chaîne de caractères. WebAssembly.Module.exports()-
Soit un objet
Module, cette méthode renvoie un tableau dont les éléments sont les descriptions de tous les exports déclarés. WebAssembly.Module.imports()-
Soit un objet
Module, cette méthode renvoie un tableau dont les éléments sont les descriptions de tous les imports déclarés.
Exemples
>Envoyer un module compilé à un worker
Dans l'exemple qui suit (voir le fichier source index-compile.html sur GitHub, et la démonstration correspondante), on compile le byte code chargé simple.wasm en utilisant la méthode WebAssembly.compileStreaming() puis en envoyant l'instance de Module résultante à un worker en utilisant postMessage().
let worker = new Worker("wasm_worker.js");
WebAssembly.compileStreaming(fetch("simple.wasm")).then((mod) =>
worker.postMessage(mod),
);
Au sein du worker (voir le fichier wasm_worker.js), on définit un objet d'import pour le module à utiliser puis on définit un gestionnaire d'évènement destiné à recevoir le module depuis le fil d'exécution principal. Lorsque le module est reçu, on en crée une instance avec la méthode WebAssembly.instantiate() puis on appelle une fonction exportée depuis l'instance.
let importObject = {
imports: {
imported_func: function (arg) {
console.log(arg);
},
},
};
onmessage = function (e) {
console.log("module reçu depuis le thread principal");
let mod = e.data;
WebAssembly.instantiate(mod, importObject).then(function (instance) {
instance.exports.exported_func();
});
};
Spécifications
| Specification |
|---|
| WebAssembly JavaScript Interface> # modules> |
Compatibilité des navigateurs
Chargement…