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, mis en cache dans IndexedDB ou être instancié à plusieurs reprises.

Le constructeur WebAssembly.Module() peut être appelé de façon synchrone pour compiler du code WebAssembly. Toutefois, on utilisera généralement la fonction asynchrone WebAssembly.compile() qui permet de compiler du bytecode ou on lira un module depuis IndexedDB.

Syntaxe

Important : La compilation de modules volumineux peut être consommatrice de ressources et de temps. Le constructeur Module() doit uniqument être utilisé lorsqu'il faut absolument avoir une compilation  synchrone. Pour tous les autres cas de figures, on privilégiera la méthode asynchrone WebAssembly.compileStreaming().

var monModule = new WebAssembly.Module(bufferSource);

Paramètres

bufferSource
Un tableau typé ou un ArrayBuffer qui contient le bytecode du module WebAssembly qu'on souhaite compiler.

Méthodes du constructeur Module

WebAssembly.Module.customSections()
Pour un module donné et une chaîne de caractères donnée, cette méthode renvoie une copie des sections personnalisées (custom sections) du module qui ont le nom correspondant à la chaîne.
WebAssembly.Module.exports()
Pour un module donné, cette méthode renvoie un tableau dont les éléments sont des descriptions des exports déclarés.
WebAssembly.Module.imports()
Pour un module donné, cette méthode renvoie un tableau dont les éléments sont des descriptions des imports déclarés.

Instances de Module

Toutes les instances de Module héritent du prototype du constructeur Module(), celui-ci peut être modifié afin de moifier le comportement de l'ensemble des instances de Module.

Propriétés

Module.prototype.constructor
Renvoie la fonction qui a créé l'instance de l'objet. Par défaut, c'est le constructeur WebAssembly.Module().
Module.prototype[@@toStringTag]
La valeur initiale de la propriété @@toStringTag est la chaîne de caractères "WebAssembly.Module".

Méthodes

Les instances de Module ne disposent pas de méthodes en propre.

Spécifications

Spécification État Commentaires
WebAssembly JavaScript Interface
La définition de 'WebAssembly.Module()' dans cette spécification.
Version de travail Brouillon de définition initiale.

Compatibilité des navigateurs

FonctionnalitéChromeEdgeFirefoxInternet ExplorerOperaSafari
Support simple5716522 Non4411
customSections5716522 Non4411
exports5716522 Non4411
imports5716522 Non4411
prototype5716522 Non4411
FonctionnalitéAndroid webviewChrome for AndroidEdge mobileFirefox for AndroidOpera AndroidiOS SafariSamsung Internet
Support simple5757 Oui1522 ?117.0
customSections5757 Oui1522 ?117.0
exports5757 Oui1522 ?117.0
imports5757 Oui1522 ?117.0
prototype5757 Oui1522 ?117.0

1. This feature is behind the Experimental JavaScript Features preference.

2. Disabled in the Firefox 52 Extended Support Release (ESR).

Voir aussi

Étiquettes et contributeurs liés au document

Contributeurs à cette page : SphinxKnight
Dernière mise à jour par : SphinxKnight,