RequireJS - Modules AMD
Un module dans RequireJS est un objet de portée et n'est pas disponible dans l'espace de noms global. Par conséquent, l'espace de noms global ne sera pas pollué. La syntaxe RequireJS permet de charger les modules plus rapidement sans se soucier de garder une trace de l'ordre des dépendances. Vous pouvez charger plusieurs versions du même module dans la même page.
Définition des modules
Le module est défini à l'aide du define()fonction; la même fonction est également utilisée pour charger le module.
Paires nom / valeur simples
Si le module est juste une collection de paires nom et valeur, vous pouvez utiliser la syntaxe suivante -
define({
state: "karnataka",
city: "bangalore"
});
Définition des fonctions
Un module peut également utiliser une fonction pour les frameworks, sans avoir de dépendances. Cela peut être fait en utilisant la syntaxe suivante -
define(function () {
//Do setup work here
return {
state: "karnataka",
city: "bangalore"
}
});
Définition de fonctions avec des dépendances
Si le module a des dépendances, le placement du premier argument (tableau de noms de dépendances), du deuxième argument (définition de la fonction) et de l'objet de retour qui définit le module est indiqué dans la syntaxe suivante -
define(["./mnc", "./startup"],
function(mnc, startup) {
return {
state: "karnataka",
city: "bangalore",
addCompany: function() {
mnc.decrement(this);
startup.add(this);
}
}
}
);
Définition d'un module en tant que fonction
Il n'est pas obligatoire pour un module de renvoyer uniquement des objets, toute valeur valide d'une fonction peut également être renvoyée. La syntaxe suivante permet de définir un module en tant que fonction -
define(["./mnc", "./startup"],
function(mnc, startup) {
return function(title) {
return title ? (window.title = title) :
startup.storeName + ' ' + mnc.name;
}
}
);
Définition d'un module avec un nom
Dans certains cas, vous devrez peut-être inclure un nom pour le module comme premier argument de define(). Cela peut être fait en utilisant la syntaxe suivante -
define("js2/title",
["js1/mnc", "js1/startup"],
function(mnc, startup) {
//Define js2/title object in here.
}
);
Chargement du module