Grunt - Guide rapide

Qu'est-ce que Grunt?

Grunt est un exécuteur de tâches JavaScript qui peut être utilisé comme outil de ligne de commande pour les objets JavaScript. C'est un gestionnaire de tâches écrit sur NodeJS.

Pourquoi utiliser Grunt?

  • Grunt peut effectuer très facilement des tâches répétitives, telles que la compilation, les tests unitaires, la réduction de fichiers, l'exécution de tests, etc.

  • Grunt comprend des tâches intégrées qui étendent les fonctionnalités de vos plugins et scripts.

  • L'écosystème de Grunt est énorme; vous pouvez automatiser tout avec très moins d'effort.

L'histoire

Les premières lignes de code source ont été ajoutées à GruntJS en 2011. Le Grunt v0.4 est sorti le 18 février 2013. Le Grunt v0.4.5 est sorti le 12 mai 2014. La version stable de Grunt est 1.0.0 rc1 qui a été publié le 11 février 2016.

Avantages

  • En utilisant Grunt, vous pouvez facilement effectuer une minification, une compilation et des tests de fichiers.

  • Grunt unifie les flux de travail des développeurs Web.

  • Vous pouvez facilement travailler avec une nouvelle base de code à l'aide de Grunt car elle contient moins d'infrastructure.

  • Il accélère le flux de travail de développement et améliore les performances des projets.

Désavantages

  • N'importe quand npm les paquets sont mis à jour, vous devez attendre que l'auteur du Grunt le mette à jour.

  • Chaque tâche est conçue pour effectuer un travail spécifié. Si vous souhaitez étendre une tâche spécifiée, vous devez utiliser quelques astuces pour faire le travail.

  • Grunt inclut un grand nombre de paramètres de configuration pour des plugins individuels. Habituellement, les fichiers de configuration Grunt sont plus longs.

Grunt est un exécuteur de tâches basé sur JavaScript, ce qui signifie qu'il peut automatiser des tâches répétitives dans un flux de travail et qu'il peut être utilisé comme outil de ligne de commande pour les objets JavaScript.

Certaines des fonctionnalités les plus importantes de GruntJS sont répertoriées ci-dessous -

  • Grunt rend le flux de travail aussi simple que l'écriture d'un fichier de configuration.

  • Vous pouvez automatiser les tâches répétitives avec un minimum d'effort.

  • Grunt est un exécuteur de tâches populaire basé sur NodeJS. Il est flexible et largement adopté.

  • Il a une approche simple qui inclut des tâches dans JS et une configuration dans JSON.

  • Grunt réduit le JavaScript, les fichiers CSS, teste des fichiers, compile des fichiers de préprocesseur CSS (SASS, LESS), etc.

  • Grunt comprend des tâches intégrées qui étendent les fonctionnalités de vos plugins et scripts.

  • Il accélère le flux de travail de développement et améliore les performances des projets.

  • Vous pouvez facilement travailler avec une nouvelle base de code à l'aide de Grunt car elle contient moins d'infrastructure.

  • L'écosystème de Grunt est énorme; vous pouvez automatiser tout avec très moins d'effort.

  • Grunt réduit le risque d'erreurs lors de l'exécution de tâches répétitives.

  • Grunt a actuellement plus de 4000 plugins.

  • Il peut être utilisé dans les grands sites de production.

Ce chapitre fournit une procédure pas à pas pour installer Grunt sur votre système.

Configuration requise pour Grunt

  • Operating System - Multiplateforme

  • Browser Support - IE (Internet Explorer 8+), Firefox, Google Chrome, Safari, Opera

Installation de Grunt

Step 1- Nous avons besoin de NodeJs pour exécuter Grunt. Pour télécharger NodeJs, ouvrez le lienhttps://nodejs.org/en/, vous verrez un écran comme indiqué ci-dessous -

Téléchargez la version Dernières fonctionnalités du fichier zip.

Step 2- Ensuite, exécutez le programme d'installation pour installer les NodeJs sur votre ordinateur.

Step 3- Ensuite, vous devez définir des variables d'environnement .

Path User Variable

  • Faites un clic droit sur My Computer.
  • Sélectionner Properties.
  • Ensuite, sélectionnez Advanced onglet et cliquez sur Environment Variables.
  • Dans la fenêtre Variables d'environnement , double-cliquez sur le CHEMIN comme indiqué à l'écran.

  • Vous obtiendrez une fenêtre Modifier la variable utilisateur comme indiqué. Ajoutez le chemin du dossier NodeJs dans le champ Valeur de la variable en tant que C: \ Program Files \ nodejs \ node_modules \ npm . Si le chemin est déjà défini pour d'autres fichiers, vous devez mettre un point-virgule (;) après cela et ajouter le chemin NodeJs comme indiqué ci-dessous -

À la fin, cliquez sur le bouton OK .

System Variable

  • Sous Variables système , double-cliquez sur Chemin comme indiqué dans l'écran suivant.

  • Vous obtiendrez une fenêtre Modifier la variable système comme indiqué. Ajoutez le chemin du dossier NodeJs dans le champ Valeur de la variable comme C: \ Program Files \ nodejs \ et cliquez sur OK comme indiqué ci-dessous -

Step 4 - Pour installer Grunt sur votre système, vous devez installer l'interface de ligne de commande (CLI) de Grunt globalement comme indiqué ci-dessous -

npm install -g grunt-cli

L'exécution de la commande ci-dessus placera la commande grunt dans votre chemin système, ce qui la fera fonctionner à partir de n'importe quel répertoire.

L'installation de grunt-cli n'installe pas le gestionnaire de tâches Grunt. Le rôle du grunt-cli est d'exécuter la version de Grunt qui a été installée à côté d'un Gruntfile . Il permet à une machine d'installer simultanément plusieurs versions de Grunt.

Step 5 - Maintenant, nous allons créer configuration files afin d'exécuter Grunt.

package.json

Le fichier package.json est placé dans le répertoire racine du projet, à côté du Gruntfile . Le package.json est utilisé pour exécuter correctement chaque dépendance répertoriée chaque fois que vous exécutez la commandenpm install dans le même dossier que package.json.

Le package de base.json peut être créé en tapant la commande suivante dans l'invite de commande -

npm init

Le fichier package.json de base sera comme indiqué ci-dessous -

{
   "name": "tutorialspoint",
   "version": "0.1.0",
   "devDependencies": {
      "grunt-contrib-jshint": "~0.10.0",
      "grunt-contrib-nodeunit": "~0.4.1",
      "grunt-contrib-uglify": "~0.5.0"
   }
}

Vous pouvez ajouter Grunt et gruntplugins dans un fichier pacakge.json existant via la commande suivante -

npm install <module> --save-dev

Dans la commande ci-dessus, <module> représente le module à installer localement. La commande ci-dessus ajoutera également le <module> à devDependencies automatiquement.

Par exemple, la commande suivante installera la dernière version de Grunt et l'ajoutera à vos devDependencies -

npm install grunt --save-dev

Gruntfile.js

Le fichier Gruntfile.js est utilisé pour définir notre configuration pour Grunt. C'est l'endroit où seront écrits nos paramètres. Le fichier de base Gruntfile.js est comme indiqué ci-dessous -

// our wrapper function (required by grunt and its plugins)
// all configuration goes inside this function
module.exports = function(grunt) {
   // CONFIGURE GRUNT
   grunt.initConfig({
      // get the configuration info from package.json file
      // this way we can use things like name and version (pkg.name)
      pkg: grunt.file.readJSON('package.json'),

      // all of our configuration goes here
      uglify: {
         // uglify task configuration
         options: {},
         build: {}
      }
   });

   // log something
   grunt.log.write('Hello world! Welcome to Tutorialspoint!!\n');

   // Load the plugin that provides the "uglify" task.
   grunt.loadNpmTasks('grunt-contrib-uglify');

   // Default task(s).
   grunt.registerTask('default', ['uglify']);
};

Pour utiliser Grunt, vous devez avoir installé Node.js. L'installation de Node.js a été expliquée dans le chapitre précédent . Vous pouvez installer les plugins Grunt et Grunt en utilisant le gestionnaire de paquets Node.js.

Avant de configurer Grunt sur le système, vous pouvez mettre à jour le gestionnaire de packages Node à l'aide de la commande suivante -

npm update -g npm

Si vous utilisez Mac ou Linux, vous devez utiliser sudo word au début de la ligne de commande pour accorder l'accès administrateur comme indiqué ci-dessous -

sudo npm update -g npm

Installation de la CLI

CLI signifie Command Line Interface qui exécute la version de Grunt qui a été installée. Pour commencer avec Grunt, vous devez installer l'interface de ligne de commande (CLI) de Grunt globalement comme indiqué ci-dessous -

npm install -g grunt-cli

L'exécution de la commande ci-dessus placera la commande grunt dans votre chemin système, ce qui la fera fonctionner à partir de n'importe quel répertoire. Vous ne pouvez pas installer le gestionnaire de tâches Grunt en installant grunt-cli . Il permet à une machine d'installer simultanément plusieurs versions de Grunt.

Fonctionnement de la CLI

La CLI recherche le Grunt installé sur votre système en utilisant le système require () chaque fois que Grunt est exécuté. En utilisant grunt-cli , vous pouvez exécuter Grunt à partir de n'importe quel répertoire de votre projet. Si vous utilisez Grunt installé localement, grunt-cli utilise la bibliothèque Grunt installée localement et applique la configuration à partir du fichier Grunt.

Travailler avec un projet existant et nouveau

Si vous travaillez avec un projet déjà configuré qui inclut package.json et Gruntfile , suivez les étapes simples comme spécifié ci-dessous -

  • Recherchez le chemin d'accès au répertoire racine du projet.
  • Vous pouvez installer des dépendances à l'aide de la commande npm install .
  • Exécutez Grunt en utilisant la commande grunt .

Si vous créez un nouveau projet, incluez les deux fichiers package.json et Gruntfile à votre projet.

  • package.json- Le fichier package.json est placé dans le répertoire racine du projet et il est utilisé pour exécuter chaque dépendance répertoriée chaque fois que vous exécutez la commande npm install dans le même dossier.

  • Gruntfile.js - Le fichier Gruntfile.js est utilisé pour écrire les paramètres de configuration du projet.

package.json

Le fichier package.json est placé dans le répertoire racine du projet, à côté du fichier Grunt et est utilisé pour exécuter chaque dépendance répertoriée chaque fois que vous exécutez la commande npm install dans le même dossier.

Vous pouvez créer le package.json de différentes manières, comme indiqué ci-dessous -

  • Vous pouvez grunt-init pour créer le fichier package.json.
  • Vous pouvez également créer un fichier package.json à l'aide de la commande npm-init .

Vous pouvez écrire les spécifications comme indiqué ci-dessous -

{
   "name": "tutorialspoint",
   "version": "0.1.0",
   "devDependencies": {
      "grunt-contrib-jshint": "~0.10.0",
      "grunt-contrib-nodeunit": "~0.4.1",
      "grunt-contrib-uglify": "~0.5.0"
   }
}

Vous pouvez ajouter Grunt et gruntplugins dans un fichier pacakge.json existant en utilisant la commande suivante -

npm install <module> --save-dev

Ici, <module> représente le module à installer localement. La commande ci-dessus installera le module spécifié et l'ajoutera automatiquement à la section devDependencies .

Par exemple, la commande suivante installera la dernière version de Grunt et l'ajoutera à vos devDependencies -

npm install grunt --save-dev

Gruntfile

Le fichier Gruntfile.js est un emplacement par défaut où vos paramètres de configuration iront pour Grunt. Le fichier Grunt comprend les parties suivantes -

  • La fonction wrapper
  • Configuration de projet et de tâche
  • Chargement des plugins et des tâches Grunt
  • Tâches personnalisées

Le fichier de base Gruntfile.js est comme indiqué ci-dessous -

// our wrapper function (required by grunt and its plugins)
// all configuration goes inside this function
module.exports = function(grunt) {

   // CONFIGURE GRUNT
   grunt.initConfig({
      // get the configuration info from package.json file
      // this way we can use things like name and version (pkg.name)
      pkg: grunt.file.readJSON('package.json'),

      // all of our configuration goes here

   });

   // Load the plugin that provides the "uglify" task
   grunt.loadNpmTasks('grunt-contrib-uglify');

   // Default task(s)
   grunt.registerTask('default', ['uglify']);
};

Fonction wrapper

Dans le code ci-dessus, module.exports est une fonction wrapper où toute la configuration entre dans cette fonction. C'est une façon d'afficher la configuration au reste de l'application.

module.exports = function(grunt) {
   //do grunt-related things here
}

Configuration de projet et de tâche

Vous pouvez configurer les tâches Grunt, une fois que votre configuration Grunt est prête. La configuration du projet peut être écrite dans la section grunt.initConfig () . Dans la fonction grunt.initConfig () , prenez les informations de configuration du fichier package.json et enregistrez-les dans pkg . Vous pouvez appeler le nom de votre projet en utilisant pkg.name et version avec pkg.version .

Chargement des plugins et des tâches Grunt

Chargez les tâches à partir d'un plugin spécifié à l'aide de la méthode grunt.loadNpmTasks . Vous pouvez installer le plugin localement en utilisantnpmet il doit être relatif au Gruntfile. Vous pouvez charger le plugin avec une simple commande comme indiqué ci-dessous -

grunt.task.loadNpmTasks(pluginName)

Tâches personnalisées

Lorsque vous exécutez Grunt via la ligne de commande, le Grunt recherchera la tâche par défaut . Dans le code ci-dessus, nous utilisons une tâche appelée uglify qui peut être exécutée à l'aide de la commande grunt . Cela revient à exécuter explicitement la commande grunt uglify et vous pouvez spécifier le nombre de tâches dans le tableau.

grunt.registerTask('default', ['uglify']);

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 pour 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 des 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'
      }
   }
});

Dans ce chapitre, créons un simple fichier Grunt en utilisant les plugins suivants -

  • grunt-contrib-uglify
  • grunt-contrib-concat
  • grunt-contrib-jshint
  • grunt-contrib-watch

Installez tous les plugins ci-dessus et suivez les étapes ci-dessous pour créer un simple Gruntfile.js -

Step 1- Vous devez créer une fonction wrapper , qui encapsule les configurations de votre Grunt.

module.exports = function(grunt) {};

Step 2 - Initialisez votre objet de configuration comme indiqué ci-dessous -

grunt.initConfig({});

Step 3- Ensuite, lisez les paramètres du projet du fichier package.json dans la propriété pkg . Cela nous permet de faire référence aux valeurs des propriétés dans votre fichier package.json .

pkg: grunt.file.readJSON('package.json')

Step 4- Ensuite, vous pouvez définir des configurations pour les tâches. Créons notre première tâche concat pour concaténer tous les fichiers présents dans le dossier src / et stocker le fichier .js concaténé sous le dossier dist / .

concat: {
   options: {
      // define a string to insert between files in the concatenated output
      separator: ';'
   },
   dist: {
      // files needs to be concatenated
      src: ['src/**/*.js'],
      // location of the concatenated output JS file
      dest: 'dist/<%= pkg.name %>.js'
   }
}

Step 5- Maintenant, créons une autre tâche appelée uglify pour minimiser notre JavaScript.

uglify: {
   options: {
      // banner will be inserted at the top of the output which displays the date and time
      banner: '/*! <%= pkg.name %> <%= grunt.template.today() %> */\n'
   },
   dist: {
      files: {
         'dist/<%= pkg.name %>.min.js': ['<%= concat.dist.dest %>']
      }
   }
}

La tâche ci-dessus crée un fichier dans le dossier dist / qui contient les fichiers .js minifiés. le<%= concat.dist.dest %>demandera à uglify de réduire le fichier généré par la tâche concat.

Step 6- Configurons le plugin JSHint en créant une tâche jshint .

jshint: {
   // define the files to lint
   files: ['Gruntfile.js', 'src/**/*.js'],
   // configure JSHint
   options: {
      // more options here if you want to override JSHint defaults
      globals: {
         jQuery: true,
      }
   }
}

La tâche jshint ci-dessus accepte un tableau de fichiers puis un objet d'options. La tâche ci-dessus recherchera toute violation de codage dans les fichiers Gruntfile.js et src / ** / *. Js .

Step 7- Ensuite, nous avons la tâche de surveillance qui recherche les modifications dans l'un des fichiers spécifiés et exécute les tâches que vous spécifiez.

watch: {
   files: ['<%= jshint.files %>'],
   tasks: ['jshint']
}

Step 8- Ensuite, nous devons charger les plugins Grunt qui ont tous été installés via _npm .

grunt.loadNpmTasks('grunt-contrib-uglify');

grunt.loadNpmTasks('grunt-contrib-jshint');

grunt.loadNpmTasks('grunt-contrib-watch');

grunt.loadNpmTasks('grunt-contrib-concat');

Step 9- Enfin, nous devons définir la tâche par défaut .

grunt.registerTask('default', ['jshint', 'concat', 'uglify']);

La tâche par défaut peut être exécutée en tapant simplement la commande grunt sur la ligne de commande.

Voici votre Gruntfile.js complet -

module.exports = function(grunt) {

   grunt.initConfig({
      pkg: grunt.file.readJSON('package.json'),
      concat: {
         options: {
            separator: ';'
         },
         dist: {
            src: ['src/**/*.js'],
            dest: 'dist/<%= pkg.name %>.js'
         }
      },
      uglify: {
         options: {
            banner: '/*! <%= pkg.name %> <%= grunt.template.today() %> */\n'
         },
         dist: {
            files: {
               'dist/<%= pkg.name %>.min.js': ['<%= concat.dist.dest %>']
            }
         }
      },
      jshint: {
         // define the files to lint
         files: ['Gruntfile.js', 'src/**/*.js'],
         // configure JSHint
         options: {
            // more options here if you want to override JSHint defaults
            globals: {
               jQuery: true,
            }
         }
      },
      watch: {
         files: ['<%= jshint.files %>'],
         tasks: ['jshint']
      }
   });

   grunt.loadNpmTasks('grunt-contrib-uglify');
   grunt.loadNpmTasks('grunt-contrib-jshint');
   grunt.loadNpmTasks('grunt-contrib-watch');
   grunt.loadNpmTasks('grunt-contrib-concat');

   grunt.registerTask('default', ['jshint', 'concat', 'uglify']);

};

Dans ce chapitre, apprenons à créer des tâches . Chaque fois que vous exécutez Grunt, une ou plusieurs tâches sont spécifiées à exécuter et notifient à Grunt ce que vous aimeriez qu'il fasse. Si vous spécifiez la tâche par défaut , elle s'exécutera par défaut.

Tâches d'alias

Chaque fois qu'une liste de tâches est spécifiée, une ou plusieurs autres tâches peuvent être aliasées par une nouvelle tâche. L'exécution de l'alias exécutera à son tour toutes les tâches spécifiées dans la liste des tâches . L' argument taskList doit être un tableau de tâches comme indiqué ci-dessous -

grunt.registerTask(taskName, [description, ] taskList)

Par exemple, lorsque vous définissez une liste de tâches avec des tâches jshint , concat et uglify et que vous spécifiez le taskName par défaut , toutes les tâches répertoriées seront exécutées automatiquement si Grunt est exécuté sans spécifier aucune tâche.

grunt.registerTask('default', ['jshint', 'concat', 'uglify']);

Vous pouvez également spécifier des arguments de tâche comme indiqué ci-dessous -

grunt.registerTask('dist', ['concat:dist', 'uglify:dist']);

Dans la tâche ci-dessus, l'alias dist exécute à la fois les tâches concat et uglify .

Multi tâches

Chaque fois que vous exécutez plusieurs tâches, Grunt recherche une propriété du même nom dans la configuration Grunt. Ces tâches peuvent avoir plusieurs configurations, qui seront définies à l'aide de cibles nommées arbitrairement .

Lorsque vous spécifiez à la fois une tâche et une cible, seule la configuration cible spécifiée sera traitée.

grunt concat:foo

La commande ci-dessus exécutera uniquement la cible foo .

Lorsque vous spécifiez uniquement une tâche, toutes les cibles seront traitées.

grunt concat

La commande ci-dessus itérera sur toutes les cibles de la tâche concat .

Lorsque vous renommez une tâche avec grunt.task.renameTask , une propriété avec un nouveau nom de tâche est recherchée dans l'objet de configuration par Grunt.

grunt.initConfig({
   log: {
      foo: [1, 2, 3],
      bar: 'Welcome to tutorialspoint',
      sap: true
   }
});

grunt.registerMultiTask('log', 'Log stuff.', function() {
   grunt.log.writeln(this.target + ': ' + this.data);
});

Dans l'exemple ci-dessus, la multi-tâche enregistrera foo: 1,2,3 si Grunt a été exécuté via grunt log: foo ou elle enregistrera bar: Bienvenue dans tutorialspoint chaque fois que vous exécutez grunt log: bar . Il enregistrera foo: 1,2,3 puis bar: Bienvenue dans tutorialspoint puis sap: true quand Grunt s'exécute en tant que grunt log .

Tâches de base

Chaque fois que vous exécutez une tâche de base, Grunt ne recherchera pas la configuration ou l'environnement. Au lieu de cela, il exécute la fonction de tâche spécifiée, transmet tous les arguments séparés par deux-points spécifiés dans comme arguments de fonction.

grunt.registerTask(taskName, [description, ] taskFunction)

Dans l'exemple suivant, la tâche enregistre foo, testant 123 si Grunt est exécuté via la commande grunt foo: testing: 123 . Chaque fois que la tâche est exécutée sans arguments en tant que grunt foo , la tâche enregistre foo, pas d'arguments .

grunt.registerTask('foo', 'A simple task to logs stuff.', function(arg1, arg2) {
   if (arguments.length === 0) {
      grunt.log.writeln(this.name + ", no args");
   } else {
      grunt.log.writeln(this.name + ", " + arg1 + " " + arg2);
   }
});

Tâches personnalisées

Si vous ne souhaitez pas suivre la structure multi-tâches , vous pouvez définir votre tâche personnalisée comme indiqué ci-dessous -

grunt.registerTask('default', 'My "default" task description.', function() {
  grunt.log.writeln('Currently running the "default" task.');
});

Il est possible d'exécuter une tâche dans une autre tâche comme indiqué ci-dessous -

grunt.registerTask('foo', 'My "foo" task.', function() {
   // Enqueue bar and baz tasks, to run after foo completes, in-order.
   grunt.task.run('bar', 'baz');
   // Or:
   grunt.task.run(['bar', 'baz']);
});

Vous pouvez également créer des tâches asynchrones comme indiqué ci-dessous -

grunt.registerTask('asyncfoo', 'My "asyncfoo" task.', function() {
   // Force task into async mode and grab a handle to the done() function.
   var done = this.async();
   // Run some sync stuff.
   grunt.log.writeln('Processing your task..');
   // Run some async stuff.
   setTimeout(function() {
      grunt.log.writeln('Finished!');
      done();
   }, 1000);
});

Vous pouvez créer des tâches qui peuvent accéder à leur nom et arguments comme indiqué ci-dessous -

grunt.registerTask('foo', 'My task "foo" .', function(a, b) {
   grunt.log.writeln(this.name, a, b);
});

// Usage:
// grunt foo
//   logs: "foo", undefined, undefined
// grunt foo:bar
//   logs: "foo", "bar", undefined
// grunt foo:bar:baz
//   logs: "foo", "bar", "baz"

Vous pouvez créer votre tâche de telle manière que, chaque fois que des erreurs sont enregistrées, les tâches peuvent échouer comme indiqué ci-dessous -

grunt.registerTask('foo', 'My task "foo" .', function() {
   if (failureOfSomeKind) {
      grunt.log.error('This is an error message.');
   }

   // If this task had errors then fail by returning false
   if (ifErrors) { return false; }

   grunt.log.writeln('This is success message');
});

Chaque fois qu'une tâche échoue, toutes les tâches suivantes seront arrêtées à moins que --force n'ait été spécifié.

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Fail synchronously.
   return false;
});

grunt.registerTask('bar', 'My task "bar" .', function() {
   var done = this.async();
   setTimeout(function() {
      // Fail asynchronously.
      done(false);
   }, 1000);
});

Les tâches peuvent dépendre d'autres tâches pour une exécution réussie. N'oubliez pas que grunt.task.requires n'exécutera pas réellement d'autres tâches, mais vérifiera seulement s'il s'est exécuté et n'a pas échoué.

grunt.registerTask('foo', 'My task "foo" .', function() {
   return false;
});

grunt.registerTask('bar', 'My task "bar" .', function() {
   // Fail task if foo task failed or never ran.
   grunt.task.requires('foo');
   // This code executes if the foo task executed successfully.
   grunt.log.writeln('Hello, World.. Welcome to Tutorialspoint!..');
});

// Usage:
// grunt foo bar doesn't log, because foo failed to execute.
// **Note: This is an example of space-separated sequential commands,
// (similar to executing two lines of code: `grunt foo` then `grunt bar`)
// grunt bar doesn't log, because foo never ran.

Les tâches peuvent même échouer lorsque les propriétés de configuration requises ne sont pas trouvées.

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Fail task if meta.name config properties is missing
   // Format 1: String 
   grunt.config.requires('meta.name');
   // or Format 2: Array
   grunt.config.requires(['meta', 'name']);
   // Log... conditionally.
   grunt.log.writeln('This only log if meta.name is defined in the config.');
});

Les tâches peuvent accéder aux propriétés de configuration comme indiqué ci-dessous -

grunt.registerTask('foo', 'My task "foo" .', function() {
   // Log the value of the property. Returns null if the property is undefined.
   grunt.log.writeln('The meta.name property is: ' + grunt.config('meta.name'));
   // Also logs the value of the property. Returns null if the property is undefined.
   grunt.log.writeln('The meta.name property is: ' + grunt.config(['meta', 'name']));
});