Gulp - Menggabungkan Tugas

Tugas memungkinkan pendekatan modular untuk mengonfigurasi Gulp. Kita perlu membuat tugas untuk setiap dependensi, yang akan kita tambahkan saat kita menemukan dan menginstal plugin lain. Tugas Gulp akan memiliki struktur berikut -

gulp.task('task-name', function() {
   //do stuff here
});

Di mana "nama-tugas" adalah nama string dan "fungsi ()" melakukan tugas Anda. "Gulp.task" mendaftarkan fungsi sebagai tugas di dalam nama dan menentukan ketergantungan pada tugas lainnya.

Menginstal Plugin

Mari kita ambil satu plugin bernama minify-cssuntuk menggabungkan dan mengecilkan semua skrip CSS. Itu dapat diinstal dengan menggunakan npm seperti yang ditunjukkan pada perintah berikut -

npm install gulp-minify-css --save-dev

Untuk bekerja dengan "plugin gulp-minify-css", Anda perlu menginstal plugin lain yang disebut "gulp-autoprefixer" seperti yang ditunjukkan pada perintah berikut -

npm install gulp-autoprefixer --save-dev

Untuk menggabungkan file CSS, instal gulp-concat seperti yang ditunjukkan pada perintah berikut -

npm install gulp-concat --save-dev

Setelah instalasi plugin, Anda perlu menulis dependensi di file konfigurasi Anda sebagai berikut -

var autoprefix = require('gulp-autoprefixer');
var minifyCSS = require('gulp-minify-css');
var concat = require('gulp-concat');

Menambahkan Tugas ke file Gulp

Kita perlu membuat tugas untuk setiap dependensi, yang akan kita tambahkan saat kita menginstal plugin. Tugas Gulp akan memiliki struktur berikut -

gulp.task('styles', function() {
   gulp.src(['src/styles/*.css'])
   .pipe(concat('styles.css'))
   .pipe(autoprefix('last 2 versions'))
   .pipe(minifyCSS())
   .pipe(gulp.dest('build/styles/'));
});

Plugin 'concat' menggabungkan file CSS dan plugin 'autoprefix' menunjukkan versi saat ini dan sebelumnya dari semua browser. Ini meminimalkan semua skrip CSS dari folder src dan menyalin ke folder build dengan memanggil metode 'dest' dengan sebuah argumen, yang mewakili direktori target.

Untuk menjalankan tugas, gunakan perintah berikut di direktori proyek Anda -

gulp styles

Demikian pula, kami akan menggunakan plugin lain yang disebut 'gulp-imagemin' untuk mengompres file gambar, yang dapat diinstal menggunakan perintah berikut -

npm install gulp-imagemin --save-dev

Anda dapat menambahkan dependensi ke file konfigurasi Anda menggunakan perintah berikut -

var imagemin = require('gulp-imagemin');

Anda dapat membuat tugas untuk dependensi yang ditentukan di atas seperti yang ditunjukkan pada kode berikut.

gulp.task('imagemin', function() {
   var img_src = 'src/images/**/*', img_dest = 'build/images';
   
   gulp.src(img_src)
   .pipe(changed(img_dest))
   .pipe(imagemin())
   .pipe(gulp.dest(img_dest));
});

Gambar terletak di "src / images / ** / *" yang disimpan di img_srcobject. Itu disalurkan ke fungsi lain yang dibuat oleh konstruktor 'imagemin'. Ini memampatkan gambar dari folder src dan menyalinnya ke folder build dengan memanggil metode 'dest' dengan sebuah argumen, yang mewakili direktori target.

Untuk menjalankan tugas, gunakan perintah berikut di direktori proyek Anda -

gulp imagemin

Menggabungkan Beberapa Tugas

Anda dapat menjalankan beberapa tugas sekaligus dengan membuat tugas default di file konfigurasi seperti yang ditunjukkan pada kode berikut -

gulp.task('default', ['imagemin', 'styles'], function() {

});

File Gulp sudah disiapkan dan siap dijalankan. Jalankan perintah berikut di direktori proyek Anda untuk menjalankan tugas gabungan di atas -

gulp

Saat menjalankan tugas menggunakan perintah di atas, Anda akan mendapatkan hasil berikut di command prompt -

C:\work>gulp
[16:08:51] Using gulpfile C:\work\gulpfile.js
[16:08:51] Starting 'imagemin'...
[16:08:51] Finished 'imagemin' after 20 ms
[16:08:51] Starting 'styles'...
[16:08:51] Finished 'styles' after 13 ms
[16:08:51] Starting 'default'...
[16:08:51] Finished 'default' after 6.13 ms
[16:08:51] gulp-imagemin: Minified 0 images