RequireJS - Optimiseur

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 lacunes.

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 se trouver 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