Grunt - Configuration des tâches

Vous pouvez définir des données de configuration spécifiques au projet pour Grunt dans le fichier Gruntfile.js .

Configuration de Grunt

Les données de configuration de la tâche peuvent être initialisées dans le Gruntfile à l'aide de la méthode grunt.initConfig () . Dans la fonction grunt.initConfig () , prenez les informations de configuration du fichier package.json. La configuration contiendra une tâche nomméeproperties et toute donnée arbitraire.

grunt.initConfig({
   jshint: {
      // configuration for jshint task
   },
   cssmin: {
      // configuration for cssmin task
   },
   // Arbitrary non-task-specific properties
   my_files: ['dir1/*.js', 'dir2/*.js'],
});

Configuration des tâches et cibles

Lorsque vous exécutez une tâche, Grunt recherche la configuration sous la propriété nommée par tâche. Nous définirons des tâches avec plusieurs configurations et options cibles comme indiqué ci-dessous -

grunt.initConfig({
   jshint: {
      myfile1: {
         // configuration for "myfile1" target options
      },
      myfile2: {
         // configuration for "myfile2" target options
      },
   },
   cssmin: {
      myfile3: {
         // configuration for "myfile3" target options
      },
   },
});

Ici, jshint tâche a myfile1 et monfich2 cibles et cssmin tâche a myfile3 cible. Lorsque vous exécutez le grunt jshint , il itérera à la fois sur la tâche et la cible pour traiter la configuration de la cible spécifiée.

Options

Définissez la propriété d' options dans la configuration de tâche qui remplace les valeurs par défaut de la tâche. Chaque cible comprend une propriété d' options qui remplace les options au niveau de la tâche. Il aura le format suivant -

grunt.initConfig({
   jshint: {
      options: {
         // task-level options that overrides task defaults
      },
      myfile: {
         options: {
            // "myfile" target options overrides task defaults
         },
      },

      myfile1: {
         // there is no option, target will use task-level options
      },
   },
});

Des dossiers

Grunt fournit quelques idées pour spécifier sur quels fichiers la tâche doit fonctionner et utilise différentes manières de spécifier les mappages de fichiers src-dest . Voici quelques-unes des propriétés supplémentaires prises en charge par les mappages src et dest -

  • filter- C'est une fonction qui spécifie le chemin du fichier src correspondant et renvoie des valeurs vraies ou fausses.

  • nonull - Il définit les modèles non correspondants lorsqu'il est défini sur true.

  • dot - Il correspond aux noms de fichiers commençant par un point ou autrement.

  • matchBase - Il correspond aux modèles contenant des barres obliques avec le nom de base du chemin.

  • expand - Il traite le mappage de fichier src-dest.

Format compact

Il spécifie le mappage de fichier src-dest par cible qui peut être utilisé pour les tâches en lecture seule et ne nécessite que la propriété src et aucune propriété dest .

grunt.initConfig({
   jshint: {
      myfile1: {
         src: ['src/file1.js','src/file2.js']
      },
   },
   cssmin: {
      myfile2: {
         src: ['src/file3.js','src/file4.js'],
         dest: 'dest/destfile.js',
      },
   },
});

Format d'objet de fichiers

Il spécifie le mappage de fichier src-dest par cible dans lequel le nom de la propriété est le fichier dest et sa valeur est le fichier src .

grunt.initConfig({
   jshint: {
      myfile1: {
         files: {
            'dest/destfile.js':['src/file1.js','src/file2.js'],
            'dest/destfile1.js':['src/file3.js','src/file4.js'],
         },
      },
      myfile2: {
         files: {
            'dest/destfile2.js':['src/file22.js','src/file23.js'],
            'dest/destfile21.js':['src/file24.js','src/file25.js'],
         },
      },
   },
});

Format de tableau de fichiers

Il spécifie le mappage de fichier src-dest par cible en utilisant des propriétés supplémentaires par mappage.

grunt.initConfig({
   jshint: {
      myfile1: {
         files: [
            {src:['src/file1.js','src/file2.js'],dest:'dest/file3.js'},
            {src:['src/file4.js','src/file4.js'],dest:'dest/file5.js'},
         ],
      },
      myfile2: {
         files: [
            {src:['src/file6.js','src/file7.js'],dest:'dest/file8/', nonull:true},
            {src:['src/file9.js','src/file10.js'],dest:'dest/file11/', filter:'isFalse'},
         ],
      },
   },
});

Formats plus anciens

Le format de fichier dest-as-target existait avant l'existence des multitâches où le chemin du fichier de destination est le nom de la cible. Le format suivant est obsolète et ne doit pas être utilisé dans le code.

grunt.initConfig({
   jshint: {
      'dest/destfile2.js':['src/file3.js','src/file4.js'],
      'dest/destfile5.js':['src/file6.js','src/file7.js'],
   },
});

Fonction de filtre personnalisé

Vous pouvez aider les fichiers cibles avec un niveau de détail élevé en utilisant la propriété filter . Le format suivant nettoie les fichiers uniquement s'il correspond à un fichier réel.

grunt.initConfig({
   clean: {
      myfile:{
         src: ['temp/**/*'],
         filter: 'isFile',
      },
   },
});

Modèles globuleux

Globbing signifie développer le nom du fichier. Grognement supports à l' aide d' expansion par le noeud-glob intégré et les bibliothèques MiniMatch . Le motif de globbing comprend les points suivants -

  • * correspond à n'importe quel nombre de caractères, mais pas / .
  • ? correspond à un seul caractère, mais pas à / .
  • ** correspond à un certain nombre de caractères, y compris / .
  • {} spécifie une liste d'expressions "ou" séparées par des virgules.
  • ! annulera la correspondance de motif au début.

Par exemple -

{src: 'myfile/file1.js', dest: ...} // it specifies the single file

{src: 'myfile/*.js', dest: ...} //it matches all the files ending wth .js

{src: 'myfile/{file1,file2}*.js', dest: ...} //defines the single node glob pattern

{src: ['myfile/*.js', '!myfile/file1.js'], dest: ...} // all files will display in alpha

// order except for file1.js

Construction dynamique de l'objet Files

Lorsque vous travaillez avec des fichiers individuels, vous pouvez utiliser des propriétés supplémentaires pour créer une liste de fichiers de manière dynamique. Lorsque vous définissez leexpand propriété à true, cela activera certaines des propriétés suivantes -

  • cwd fait correspondre tous les src à ce chemin.

  • src correspond aux modèles à faire correspondre, par rapport au cwd .

  • La propriété dest spécifie le préfixe du chemin de destination.

  • ext remplacera une extension existante par une valeur générée dans les chemins dest .

  • extDot indique où se trouve la période indiquant l'extension. Il utilise soit la première période, soit la dernière période; par défaut, il est défini sur la première période

  • flatten supprime toutes les parties de chemin des chemins de destination .

  • rename spécifie une chaîne contenant la nouvelle destination et le nouveau nom de fichier.

La propriété Rename

Il s'agit d'une fonction JavaScript unique qui renvoie une chaîne et vous ne pouvez pas utiliser une valeur de chaîne pour renommer. Dans l'exemple suivant, la tâche de copie créera une sauvegarde de README.md.

grunt.initConfig({
   copy: {
      backup: {
         files: [{
            expand: true,
            src: ['docs/README.md'],    // creating a backup of README.md
            rename: function () {       // specifies the rename function
               return 'docs/BACKUP.txt'; // returns a string with the complete destination
            }
         }]
      }
   }
});

Modèles

Vous pouvez spécifier les modèles en utilisant des délimiteurs < %% > . Ils seront développés automatiquement lorsqu'ils seront lus à partir de la configuration. Il comprend deux types de propriétés -

  • <%= prop.subprop %>property est utilisé pour développer la valeur de prop.subprop dans la configuration qui peut référencer les valeurs de chaîne, les tableaux et d'autres objets.

  • <% %> property exécute le code JavaScript en ligne qui est utilisé pour le flux de contrôle ou la boucle.

Par exemple -

grunt.initConfig({
   concat: {
      myfile: {
         options: {
            banner: '/* <%= val %> */\n',
         },
         src: ['<%= myval %>', 'file3/*.js'],
         dest: 'build/<%= file3 %>.js',
      },
   },
   // properties used in task configuration templates
   file1: 'c',
   file2: 'b<%= file1 %>d',
   file3: 'a<%= file2 %>e',
   myval: ['file1/*.js', 'file2/*.js'],
});

Importation de données externes

Vous pouvez importer des données externes à partir du fichier package.json . Le plugin grunt- contrib - uglify peut être utilisé pour réduire le fichier source et il crée un commentaire de bannière en utilisant des métadonnées. Vous pouvez utiliser grunt.file.readJSON et grunt.file.readYAML pour importer des données JSON et YAML.

Par exemple -

grunt.initConfig({
   pkg: grunt.file.readJSON('package.json'),
   uglify: {
      options: {
         banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> */\n'
      },
      dist: {
         src: 'src/<%= pkg.name %>.js',
         dest: 'dist/<%= pkg.name %>.min.js'
      }
   }
});