Grunt - Memulai

Untuk menggunakan Grunt, Anda harus menginstal Node.js. Instalasi Node.js telah dijelaskan di bab sebelumnya . Anda dapat menginstal plugin Grunt dan Grunt dengan menggunakan manajer paket Node.js.

Sebelum mengatur Grunt pada sistem, Anda dapat memperbarui Node package manager dengan menggunakan perintah berikut -

npm update -g npm

Jika Anda menggunakan Mac atau Linux, Anda perlu menggunakan sudo word di awal baris perintah untuk memberikan akses administrator seperti yang ditunjukkan di bawah ini -

sudo npm update -g npm

Instalasi CLI

CLI adalah singkatan dari Command Line Interface yang menjalankan versi Grunt yang telah diinstal. Untuk memulai dengan Grunt, Anda perlu menginstal antarmuka baris perintah (CLI) Grunt secara global seperti yang ditunjukkan di bawah ini -

npm install -g grunt-cli

Menjalankan perintah di atas akan menempatkan perintah grunt di jalur sistem Anda, yang membuatnya dijalankan dari direktori mana pun. Anda tidak dapat menginstal runner tugas Grunt dengan menginstal grunt-cli . Ini memungkinkan mesin menginstal beberapa versi Grunt secara bersamaan.

Bekerja dari CLI

CLI mencari Grunt yang diinstal pada sistem Anda dengan menggunakan sistem require () setiap kali Grunt dijalankan. Dengan menggunakan grunt-cli , Anda dapat menjalankan Grunt dari direktori mana pun di project Anda. Jika Anda menggunakan Grunt yang diinstal secara lokal, maka grunt-cli menggunakan library Grunt yang diinstal secara lokal dan menerapkan konfigurasi dari file Grunt.

Bekerja dengan proyek yang sudah ada dan baru

Jika Anda bekerja dengan proyek yang sudah dikonfigurasi yang menyertakan package.json dan Gruntfile , ikuti langkah-langkah sederhana seperti yang ditentukan di bawah ini -

  • Temukan jalur ke direktori akar proyek.
  • Anda dapat menginstal dependensi menggunakan perintah npm install .
  • Jalankan Grunt menggunakan perintah grunt .

Jika Anda membuat proyek baru, sertakan dua file package.json dan Gruntfile ke proyek Anda.

  • package.json- File package.json ditempatkan di direktori root proyek dan digunakan untuk menjalankan setiap dependensi yang terdaftar setiap kali Anda menjalankan perintah npm install di folder yang sama.

  • Gruntfile.js - File Gruntfile.js digunakan untuk menulis pengaturan konfigurasi untuk proyek tersebut.

package.json

File package.json ditempatkan di direktori root proyek, di samping Gruntfile dan digunakan untuk menjalankan setiap dependensi yang terdaftar setiap kali Anda menjalankan perintah npm install di folder yang sama.

Anda dapat membuat package.json dengan berbagai cara seperti yang tercantum di bawah ini -

  • Anda dapat grunt-init untuk membuat file package.json.
  • Anda juga dapat membuat file package.json dengan menggunakan perintah npm-init .

Anda dapat menulis spesifikasi seperti yang ditunjukkan di bawah ini -

{
   "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"
   }
}

Anda dapat menambahkan Grunt dan gruntplugins ke dalam file pacakge.json yang ada dengan menggunakan perintah berikut -

npm install <module> --save-dev

Di sini, <module> mewakili modul yang akan diinstal secara lokal. Perintah di atas akan menginstal modul yang ditentukan dan secara otomatis menambahkannya ke bagian devDependencies .

Misalnya, perintah berikut akan menginstal versi terbaru Grunt dan menambahkannya ke devDependencies Anda -

npm install grunt --save-dev

Gruntfile

File Gruntfile.js adalah tempat default di mana pengaturan konfigurasi Anda akan digunakan untuk Grunt. File Grunt mencakup bagian-bagian berikut -

  • Fungsi pembungkus
  • Konfigurasi proyek dan tugas
  • Memuat plugin dan tugas Grunt
  • Tugas khusus

File Gruntfile.js dasar seperti yang ditunjukkan di bawah ini -

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

Fungsi Pembungkus

Pada kode di atas, module.exports adalah fungsi pembungkus di mana seluruh konfigurasi masuk ke dalam fungsi ini. Ini adalah cara menampilkan konfigurasi ke aplikasi lainnya.

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

Konfigurasi Proyek dan Tugas

Anda dapat mengonfigurasi tugas Grunt, setelah konfigurasi Grunt Anda siap. Konfigurasi proyek dapat ditulis di bagian grunt.initConfig () . Di dalam fungsi grunt.initConfig () , ambil informasi konfigurasi dari file package.json dan simpan ke pkg . Anda dapat memanggil nama proyek Anda menggunakan pkg.name dan versinya dengan pkg.version .

Memuat Plugin dan Tugas Grunt

Muat tugas dari plugin yang ditentukan dengan menggunakan metode grunt.loadNpmTasks . Anda dapat menginstal plugin secara lokal dengan menggunakannpmdan itu harus relatif terhadap Gruntfile. Anda dapat memuat plugin dengan perintah sederhana seperti yang ditunjukkan di bawah ini -

grunt.task.loadNpmTasks(pluginName)

Tugas Kustom

Saat Anda menjalankan Grunt melalui baris perintah, Grunt akan mencari tugas default . Pada kode di atas, kami menggunakan tugas bernama uglify yang dapat dijalankan menggunakan perintah grunt . Ini sama dengan menjalankan perintah grunt uglify secara eksplisit dan Anda dapat menentukan jumlah tugas dalam larik.

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