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