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