RequireJS - Guide rapide
RequireJS est une bibliothèque JavaScript et un chargeur de fichiers qui gère les dépendances entre les fichiers JavaScript et en programmation modulaire. Cela contribue également à améliorer la vitesse et la qualité du code.
RequireJS a été développé par David Mark et sa version initiale v1.0.0 a été publiée en 2009. Il s'agit d'une open source et la version 2.3.3 est sa récente version stable.
Pourquoi utiliser RequireJS?
Il s'agit d'une bibliothèque JavaScript open source sous licence MIT.
Il fournit un chargement de module asynchrone.
Il a la capacité de charger des dépendances imbriquées.
Si vous avez beaucoup de petits fichiers, ne vous souciez pas du suivi de l'ordre des dépendances.
Il prend en charge les plugins et charge plus d'un fichier JavaScript.
Caractéristiques de RequireJS
Il gère les dépendances entre les fichiers JavaScript et améliore la vitesse et la qualité du code.
Il combine et réduit les modules en un seul script pour une expérience optimisée.
Il réduit la complexité du code dans les grandes applications.
Il rassemble différents fichiers JavaScript de différents modules au moment de la compilation.
Il permet un débogage facile car il charge les fichiers à partir de balises de script simples.
Dans ce chapitre, nous allons comprendre comment configurer l'environnement pour RequireJS. Pour cela, vous devez télécharger la dernière version de la bibliothèque RequireJS. Vous pouvez télécharger la version réduite ou la version détaillée .
Après le téléchargement, nous devons inclure le require.js dans votre dossier libs et la structure de votre projet doit être comme indiqué ci-dessous -
projectname/
|--index.html
|--libs/
|---main.js
|---require.js
|---helper/
|----util.js
Nous devons définir un fichier html comme index.html où RequireJS est chargé comme indiqué ci-dessous.
<html>
<head>
<script data-main = "libs/main" src = "libs/require.js"></script>
</head>
<body>
<h1> RequireJS Sample Page </h1>
</body>
</html>
Notez que seulement require.js avec un appel RequireJS est inclus dans la balise de script pour charger le script.
RequireJS dans Node
Il existe deux façons d'obtenir l'adaptateur Node.
npm - Vous pouvez installer la dernière version de requirejs à partir de l'invite de commande comme indiqué ci-dessous.
npm install requirejs
Télécharger r.js - Vous pouvez télécharger le r.jsfichier à partir de la page de téléchargement et source à partir der.js page du référentiel .
RequireJS peut être initialisé en passant la configuration principale dans le modèle HTML via l' attribut data-main . Il est utilisé par RequireJS pour savoir quel module charger dans votre application.
Par exemple -
<script data-main = "scripts/main" src = "scripts/require.js"></script>
Pour inclure le fichier Require.js, vous devez ajouter la balise de script dans le fichier html. Dans la balise de script, ajoutez ledata-mainattribut pour charger le module. Cela peut être considéré comme le principal point d'entrée de votre application. Le script / main est un fichier JavaScript principal d'une application qui contient la configuration RequireJS.
Options de configuration
Voici les options de configuration qui peuvent être définies lors du chargement du premier module d'application -
baseUrl- C'est un chemin de route pour tous les modules qui sont chargés via RequireJS. La baseUrl est indiquée par une chaîne commençant par "slash (/)", contenant un protocole et se terminant par l'extension ".js". Si aucune baseUrl n'est spécifiée, RequireJS utilise le chemin de l'attribut data-main comme baseUrl.
paths- Il spécifie les mappages de chemin pour les modules qui sont relatifs à baseUrl. Il ajoute automatiquement l'extension .js à un chemin lors du mappage du nom du module.
shim - Il permet l'utilisation de bibliothèques non AMD avec RequireJS en configurant leurs dépendances et en exportant leurs valeurs globales.
map - Pour le module donné, une application utilise le même module de versions différentes pour des objectifs différents en partageant leurs identifiants pour utiliser le même code pour différentes conditions.
config- Il fournit la configuration à un module en utilisant l' option config et cela peut être fait en utilisant la dépendance spéciale "module" et en appelant sonmodule.config() fonction.
urlArgs- Les arguments de la chaîne de requête sont utilisés pour récupérer toutes les ressources chargées à l'aide de RequireJS. Il est utilisé pour le contournement du cache en cas de configuration incorrecte du navigateur ou du serveur.
waitSeconds- Il spécifie le nombre de secondes à attendre avant de vomir lors du chargement du script. La valeur par défaut est "7" secondes et "0" désactive le délai.
packages - Il fournit les packages CommonJS pour configurer les modules de chargement.
context - Il fournit le nom du chargement de contexte qui permet le chargement de différents modules dans une page.
deps - C'est un tableau de dépendances qui est requis lorsque Require est spécifié en tant qu'objet de configuration avant de charger RequireJS.
callback - Il exécute une fonction après le chargement des dépendances et est requis lorsque Require est spécifié comme objet de configuration avant de charger RequireJS.
xhtml - Il est utilisé pour créer les éléments de script en utilisant le document.createElementNS()méthode lorsque cette option est définie sur true .
scriptType- Il définit la valeur de l'attribut de type de script utilisé dans le document. Le type par défaut est "text / javascript".
skipDataMain- Il ignore l' analyse des attributs principaux des données lors du chargement du module, si cette option est définie sur true .
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 de noms et de valeurs, 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
La fonction define () peut être utilisée pour charger les modules (le module peut être un objet, une fonction, une classe ou un code qui est exécuté après le chargement d'un module). Vous pouvez charger différentes versions du même module dans la même page. Les différentes versions peuvent être analysées dans le même ordre, même si elles sont chargées dans un ordre différent.
Syntaxe
define(['module1', 'module2'], function (module1, module2) {
//define the module value by returning a value
return function () {};
});
Vous pouvez transmettre une liste de noms de modules lorsque vous définissez un module et RequireJS peut être utilisé pour récupérer ces modules avant d'exécuter le module. Ces modules peuvent être passés comme paramètres dudefinition function.
Exemple
L'exemple suivant montre l'utilisation de la fonction define () lors du chargement des modules. Créez un fichier html avec le nom index.html et placez-y le code suivant -
<!DOCTYPE html>
<html>
<head>
<title>Define() Function</title>
<script data-main = "main" src = "require.js"></script>
</head>
<body>
<h2>RequireJS Define() Function Example</h2>
</body>
</html>
Créer un jsfichier avec le nom main.js et ajoutez-y le code suivant -
define(function (require) {
var myteam = require("./team");
var mylogger = require("./player");
alert("Player Name : " + myteam.player);
mylogger.myfunc();
});
Maintenant, créez deux autres jsfichiers avec les noms team.js et player.js et placez respectivement le code suivant -
team.js
define({
player: "Sachin Tendulkar",
team : "India"
});
player.js
define(function (require) {
var myteam = require("./team");
return {
myfunc: function () {
document.write("Name: " + myteam.player + ", Country: " + myteam.team);
}
};
});
Production
Ouvrez le fichier HTML dans un navigateur; vous recevrez une sortie comme dans la capture d'écran suivante -
Cliquez sur le bouton "OK", vous obtiendrez une autre sortie des modules -
Dans ce chapitre, nous discuterons de l'optimisation dans RequireJS. L'optimiseur de RequireJS présente les caractéristiques suivantes -
Combine les fichiers de script avec l'aide d' UglifyJS pour l'utilisation par défaut ou de Closure Compiler pour l'utilisation de Java
Combine les fichiers CSS ensemble.
L'optimiseur est un composant du r.jsadaptateur pour Node et Nashorn . Il est développé pour faire partie d'un processus de construction et non pour le processus de développement.
Exemple
Après avoir téléchargé le r.js dans votre dossier de projet, la structure du dossier doit ressembler à celle ci-dessous -
projectfolder/
|-->index.html
|-->CSS/
|--->main.css
|--->other.css
|-->libs
|--->require.js
|--->main.js
|--->dependent1.js
|--->dependent2.js
|--->dependent3.js
Votre fichier HTML ressemblera à celui ci-dessous -
<html>
<head>
<script data-main = "libs/main" src = "libs/require.js"></script>
</head>
<body>
<h1> RequireJS Sample Page </h1>
</body>
</html>
Votre fichier main.js ressemblera à celui ci-dessous -
require(["dependent1", "dependent2", "dependent3"], function (dependent1, dependent2,
dependent3) {
});
Votre fichier main.css ressemblera à celui ci-dessous -
@import url("other.css");
.app {
background: transparent url(../../img/app.png);
}
Configuration de base de l'optimiseur
Vous pouvez utiliser les arguments de ligne de commande ou les propriétés de construction de profil pour définir le projet, les deux sont échangeables entre eux.
Voici la syntaxe de la ligne de commande -
node r.js -o baseUrl = . paths.jquery = content/path/jquery
name = main out = main-built.js
Voici la syntaxe du profil de construction -
({
baseUrl: ".",
paths: {
jquery: "content/path/jquery"
},
name: "main",
out: "main-built.js"
})
Après cela, vous pouvez transmettre le nom du profil de construction à l'optimiseur dans la ligne de commande, comme indiqué ci-dessous -
node r.js -o build.js
Il y a quelques lacunes dans la syntaxe des arguments de ligne de commande. Une utilisation combinée des arguments de ligne de commande ou des propriétés de création de profil peut surmonter ces inconvénients.
Optimiser un seul fichier JS
Pour optimiser un seul fichier JS, vous devez créer un fichier JS contenant le contenu de toutes ses dépendances. Votre fichier doit ressembler à celui ci-dessous -
({
baseUrl: "js/shop",
paths: {
"jquery": "jquery",
"backbone": "backbone",
"underscore": "underscore"
},
shim: {
"backbone": {
"department": ["underscore", "jquery"],
"dependent": "Backbone"
},
"underscore": {
exports: "_"
}
},
name: "../main",
out: "../built/js/main.js"
})
Maintenant, vous pouvez créer le fichier main.js qui contient toutes les dépendances pour app. Ce fichier est utilisé dans le fichier HTML pour charger tous les fichiers JS avec une seule requête. Notez que les fichiers créés ne doivent pas être présents dans le répertoire du code source; les fichiers doivent être dans la copie du projet.
Utilisation des ressources CDN
L'optimiseur ne charge pas les scripts à l'aide des ressources réseau / CDN (Content Delivery Network). Dans le cas où les scripts doivent être chargés à l'aide d'un CDN, vous devez mapper ces fichiers sur un nom de module et télécharger les fichiers sur votre chemin de fichier local. Vous pouvez utiliser le mot spécial «vide» dans la configuration du chemin du profil de construction comme indiqué dans la syntaxe suivante -
({
baseUrl: "js",
name: "mainCDN",
out: "js/mainCDN-built.js",
paths: {
jquery: "empty:"
}
})
Le fichier principal ressemblera à celui ci-dessous -
requirejs.config({
paths: {
'jquery': 'https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min'
}
});
require(['jquery'], function ($) {
});
Optimiser un seul fichier CSS
Les fichiers CSS sont optimisés en utilisant les paramètres suivants directement dans la ligne de commande comme indiqué ci-dessous -
node ../../r.js -o cssIn = main.css out = main-built.css
Les fichiers CSS peuvent également être optimisés dans un fichier de construction en utilisant les mêmes propriétés que celles indiquées ci-dessous -
...
cssIn:"main.css",
out:"main-built.css"
...
Les deux méthodes ci-dessus sont autorisées et créeront un fichier appelé projectfolder / css / mainbuild.css . Ce fichier aura le contenu de main.css, les chemins url () correctement ajustés et les commentaires supprimés.
Optimiser l'ensemble du projet
L'optimiseur utilise le profil de construction pour optimiser tous les css et jsdes dossiers. Dans l'exemple suivant, le fichier build.js est créé.
({
baseUrl: "js/shop",
appDir: '.',
paths: {
"jquery": "jquery",
"backbone": "backbone",
"underscore": "underscore"
},
shim: {
"backbone": {
"deps": ["underscore", "jquery"],
"exports": "Backbone"
},
"underscore": {
exports: "_"
}
},
optimizeCss: "standard.keepLines",
modules: [
{
name: "app"
}
],
dir: "../built"
})
Le fichier build.js demande à RequireJS de copier tous les dossiers d'application (paramètre appDir) dans le dossier de sortie généré (paramètre dir) et d'appliquer toutes les optimisations aux fichiers situés dans le dossier de sortie. Exécutez la commande suivante pour créer un profil dans le dossier de l'application -
node r.js -o build.js
RequireJS utilise jQuery comme une autre dépendance et s'inscrit en tant que module nommé jquery en minuscules et, par défaut, s'enregistre également en utilisant les fonctions globales $ et jQuery tout en utilisant AMD / RequireJS.
Chargement de jQuery
require(['jquery'], function($) {
//code here
}
Vous pouvez charger plusieurs bibliothèques personnalisées avec le jQuery comme indiqué ci-dessous -
require(['custom_library_path','jquery'], function(load_library,$) {
//related code of $ and load_library
});
Le tableau suivant montre l'utilisation de jQuery avec RequireJS pour spécifier leurs dépendances.
Sr.No. | Types et description |
---|---|
1 | Utilisation de Shim Config jQuery utilise la configuration shim pour définir les dépendances des plugins jQuery. |
2 | Chargement de jQuery à partir du CDN jQuery utilise CDN pour définir les dépendances des plugins jQuery. |
L'adaptateur Node peut être utilisé avec l'implémentation du chemin de recherche Require et Node. Si aucune configuration de module n'est utilisée par RequireJS, vous pouvez utiliser les modules basés sur Node existants sans les modifier. Vous pouvez installer les packages de nœuds dans le répertoire node_modules du projet à l'aide de la commande npm.
Node chargera les modules uniquement à partir du disque local et les options de configuration telles que la carte, les packages, les chemins, etc. ne seront appliquées que lorsque le module est chargé par RequireJS.
Installation du nœud
Vous pouvez installer l'adaptateur de nœud en utilisant la commande suivante qui installera les derniers fichiers de version -
npm install requirejs
Vous pouvez également installer le Node des manières suivantes:
Vous pouvez télécharger le r.js à partir de ce lien et le conserver dans votre dossier de projet.
Obtenir la source du référentiel r.js ou l' installer via dist.js nœud .
Utilisation de Node
Pour utiliser le nœud, vous devez avoir require ('requirejs') et déplacer la fonction require dans la configuration vers le fichier main.js de niveau supérieur.
Par exemple -
var requirejs = require('requirejs');
requirejs.config({
//load the mode modules to top level JS file
//by passing the top level main.js require function to requirejs
nodeRequire: require
});
requirejs(['name1', 'name2'],
function (name1, name2) {
//by using requirejs config, name1 and name2 are loaded
//node's require loads the module, if they did not find these
}
);
Création de modules de nœuds avec AMD ou RequireJS
Vous pouvez faire fonctionner le module de code avec RequireJS et Node, sans avoir besoin des utilisateurs de la bibliothèque, puis utiliser le package amdefine pour accomplir ce travail.
Par exemple -
if (typeof define !== 'function') {
var define = require('amdefine')(module);
}
define(function(require) {
var myval = require('dependency');
//The returned value from the function can be used
//as module which is visible to Node.
return function () {};
});
Optimiseur en tant que module de nœud
Le module Node utilise l'optimiseur RequireJS comme méthode d' optimisation en utilisant l'appel de fonction au lieu d'utiliser l'outil de ligne de commande.
Par exemple -
var requirejs = require('requirejs');
var config = {
baseUrl: '../directory/scripts',
name: 'main',
out: '../build/main-built.js'
};
requirejs.optimize(config, function (buildResponse) {
//The text output of the modules specify by using buildResponse
//and loads the built file for the contents
//get the optimized file contents by using config.out
var contents = fs.readFileSync(config.out, 'utf8');
}, function(err) {
//code for optimization err callback
});
Dojo est une boîte à outils JavaScript basée sur l'architecture du module AMD qui fournit des modules supplémentaires pour ajouter des fonctionnalités supplémentaires à l'application Web et permet également d'économiser du temps et de l'évolutivité dans le processus de développement de l'application Web.
Exemple
L'exemple suivant montre l'utilisation de Dojo avec RequireJS. Créez un fichier html avec le nom index.html et placez-y le code suivant -
<!DOCTYPE html>
<html>
<head>
<title>RequireJS Dojo</title>
<script data-main="app" src="lib/require.js"></script>
</head>
<body>
<h2>RequireJS Dojo</h2>
<p>
Hello... ...
</p>
</body>
</html>
Créer un jsfichier avec le nom app.js et ajoutez-y le code suivant -
require ({
//You can configure loading modules from the lib directory
baseUrl: 'lib',
paths: {
//mapping of package
dojo: 'http://sfoster.dojotoolkit.org/dojobox/1.7-branch/dojo'
}
}, [
//modules which we are using here
'dojo/dom'
], function(dom) {
//using the 'byId' method from dom module
var mydojo = dom.byId('dojo_val')
mydojo.innerHTML = "The text is displaying via dojo/dom";
}
);
Production
Ouvrez le fichier HTML dans un navigateur; vous recevrez la sortie suivante -
Le format du module est défini par CommonJS. Il est défini sans fournir une option égale de navigateurs à d'autres environnements JavaScript. Par conséquent, la spécification CommonJS recommande les formats de transport et une exigence asynchrone . Vous pouvez facilement convertir le format de module CommonJS traditionnel pour qu'il fonctionne avec RequireJS. Mais, tous les modules ne seront pas convertis au nouveau format. Certaines des exceptions sont énumérées ci-dessous -
- Modules avec code conditionnel pour effectuer un appel obligatoire.
- Modules avec dépendances circulaires.
Conversion manuelle
Les modules CommonJS peuvent être convertis manuellement au format RequireJS en utilisant la syntaxe suivante -
define(function(require, exports, module) {
//place CommonJS module content here
});
Outil de conversion
Les modules CommonJS peuvent être convertis au format RequireJS à l'aide de l' outil de conversion de projet r.js , qui est intégré au fichier r.js. Vous devez spécifier le chemin du fichier à convertir et le dossier de sortie comme indiqué ci-dessous -
node r.js -convert path/to/commonjs/modules/ path/to/output
Définition de la valeur exportée
Certains des systèmes de CommonJS permettent de définir la valeur exportée en affectant la valeur exportée en tant que module.exports Mais RequireJS prend en charge le moyen le plus simple de renvoyer la valeur de la fonction passée à définir. L'avantage de ceci est que vous n'avez pas besoin des arguments d'exportation et de fonction du module, vous pouvez donc les laisser hors de la définition du module comme indiqué ci-dessous -
define(function (require) {
var name = require('name');
//Define the module as exporting a function
return function () {
name.doSomething();
};
});
Syntaxe alternative
L'autre façon de spécifier des dépendances est via un argument de tableau de dépendances define () . Mais, l'ordre des noms dans le tableau de dépendances doit correspondre à l'ordre des arguments passés à la fonction de définition define () comme indiqué ci-dessous -
define(['name'], function (name) {
return function () {
name.doSomething();
};
});
Chargement de modules à partir de packages CommonJS
Pour connaître l'emplacement et les attributs de package, les modules sont chargés dans les packages CommonJS à l'aide de RequireJS en configurant la configuration RequireJS.
Outil d'optimisation
L'outil d'optimisation est présent dans RequireJS qui peut combiner les définitions de module dans des ensembles optimisés pour la livraison par navigateur. Il fonctionne comme un outil de ligne de commande afin que vous puissiez l'utiliser dans le cadre du déploiement de code.
RequireJS contient un petit ensemble de plugins qui permettent de charger différents types de ressources en tant que dépendances. Voici une liste des plugins disponibles dans RequireJS -
- text
- domReady
- i18n
- Chargement CSS
texte
Le plug-in de texte est utilisé pour charger des ressources textuelles de manière asynchrone, ce qui est principalement utilisé pour insérer le contenu HTML dans des fichiers JavaScript. Il peut être chargé lorsque vous utilisez le texte! préfixe dans tout appel de module require ou define et transmettez l'extension de fichier au plug-in. Comparé au chargement normal du module, le plug-in de texte charge les modules à l'aide de XHR et n'ajoutera pas le code à l'en-tête en tant quescript marque.
La ressource de fichier texte peut être incluse en tant que dépendance dans le code comme -
require(["mymodule", "text!mymodule.html", "text!mymodule.css"],
function(mymodule, html, css) {
//the html and css variables will be the text
//of the mymodule.html file and mymodule.css files respectively
}
);
domReady
RequireJS peut être utilisé pour charger des scripts avant que DOM ne soit prêt et les développeurs peuvent interagir avec DOM, uniquement lorsque les scripts se chargent complètement. Parfois, les scripts peuvent être chargés avant que DOM ne soit prêt. Donc, pour surmonter ce problème, RequireJS fournit une approche moderne appelée événement DOMContentLoaded qui appelle la fonction domReady une fois que DOM est prêt.
require(['domReady'], function(domReady) {
domReady(function() {
//the domReady function is called when DOM is ready
//which is safe to manipulate DOM nodes in this function
});
});
i18n
Il peut être utilisé avec plusieurs paramètres régionaux qui fournissent i18nprise en charge du bundle qui sera chargé automatiquement lorsqu'un module ou une dépendance spécifie "i18n!" préfixe. Pour en profiter, téléchargez-le et placez-le dans le même répertoire où se trouve votre fichier JavaScript principal. Placez ce plug-in dans le répertoire appelé "nls" pour localiser vos fichiers de localisation.
Par exemple, supposons que nous ayons un fichier js appelé country.js avec le contenu suivant et placez-le dans le répertoire sous le nom mydirectory / nls / country.js -
define({
"root": {
"india": "india",
"australia": "australia",
"england": "england"
}
});
Vous pouvez ajouter une traduction spécifique à un fichier en utilisant les paramètres régionaux fr-fr et le code ci-dessus changera comme -
define({
"root": {
"title": "title",
"header": "header",
"description": "description"
},
"es-es": true
});
Ensuite, spécifiez le fichier dans mydirectory / nls / es-es / country.js avec le contenu suivant -
define({
"root": {
"title": "título",
"header": "cabecera",
"description": "descripción"
},
"es-es": true
});
Vous pouvez définir la locale en la transmettant au plugin à l'aide du module config dans le fichier main.js comme indiqué ci-dessous -
requirejs.config({
config: {
//set the config for the i18n plugin
i18n: {
locale: 'es-es'
}
}
});
Chargement CSS avec RequireJS
Vous pouvez utiliser certains plug-ins pour charger le fichier CSS en ajoutant simplement au lien d'en-tête pour charger le fichier CSS.
Le CSS peut être chargé en utilisant votre propre fonction comme indiqué ci-dessous -
function myCss(url) {
var mylink = document.createElement("mylink");
mylink.type = "text/css";
mylink.rel = "stylesheet";
mylink.href = url;
document.getElementsByTagName("head")[0].appendChild(mylink);
}