Gulp - Panduan Cepat

Apa Gulp?

Gulp adalah pelari tugas yang menggunakan Node.js sebagai platform. Gulp murni menggunakan kode JavaScript dan membantu menjalankan tugas front-end dan aplikasi web skala besar. Itu membangun tugas-tugas otomatis sistem seperti minifikasi CSS dan HTML, menggabungkan file pustaka, dan menyusun file SASS. Tugas-tugas ini dapat dijalankan menggunakan skrip Shell atau Bash pada baris perintah.

Mengapa menggunakan Gulp?

  • Ini lebih pendek, lebih sederhana dan lebih cepat dibandingkan dengan pelari tugas lainnya.
  • Menggunakan SASS dan LESS sebagai praprosesor CSS.
  • Refresh halaman secara otomatis setelah mengedit file sumber.
  • Mudah untuk memahami dan membangun Gulpfile.js karena, ia menggunakan kode JavaScript murni untuk membangun tugasnya.

Sejarah

Semua dokumentasi Gulp dilindungi oleh lisensi CC0. Awalnya, Gulp v1.0.0 dirilis pada 15 Januari 2015, dan versi Gulp saat ini adalahv3.9.0.

fitur

  • Menyediakan minifikasi dan penggabungan.
  • Menggunakan kode JavaScript murni.
  • Mengonversi kompilasi LESS atau SASS ke CSS.
  • Mengelola manipulasi file dalam memori dan meningkatkan kecepatan dengan menggunakan platform Node.js.

Keuntungan

  • Keunggulan kecepatan besar dibandingkan pelari tugas lainnya
  • Mudah untuk dikodekan dan dimengerti.
  • Mudah untuk menguji aplikasi web ..
  • Plugin mudah digunakan dan dirancang untuk melakukan satu hal dalam satu waktu.
  • Melakukan tugas berulang berulang kali seperti mengecilkan stylesheet, mengompresi gambar, dll.

Kekurangan

  • Lebih banyak dependensi dan merupakan pendatang baru dibandingkan dengan Grunt.
  • Menggunakan plugin Gulp, Anda tidak dapat melakukan banyak tugas.
  • Konfigurasi tidak sebersih Grunt.

Artikel ini memberikan prosedur langkah-demi-langkah instalasi Gulp.

Persyaratan Sistem untuk Gulp

  • Operating System - Lintas platform

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

Pemasangan Gulp

Step 1- Kami membutuhkan Node.js untuk menjalankan contoh Gulp. Untuk mengunduh Node.js, bukahttps://nodejs.org/en/, Anda akan melihat layar seperti di bawah ini -

Unduh versi fitur terbaru dari file zip.

Step 2- Selanjutnya, jalankan setup untuk menginstal NodeJs di komputer Anda.

Step 3 - Anda perlu mengatur variabel lingkungan.

Variabel Pengguna Jalur

  • Klik kanan pada My Computer.
  • Pilih Properties.
  • Pilih tab Advanced dan klik 'Variabel Lingkungan'.
  • Di bawah jendela Variabel Lingkungan, klik dua kali pada PATH seperti yang ditunjukkan pada layar berikut.

  • Anda akan mendapatkan jendela Edit Variabel Pengguna seperti yang ditunjukkan pada tangkapan layar berikut. Tambahkan jalur folder Node.js di bidang Nilai Variabel sebagai C: \ Program Files \ nodejs \ node_modules \ npm. Jika jalur sudah disetel untuk file lain, maka Anda perlu meletakkan titik koma (;) setelah itu dan menambahkan jalur Node.js seperti yang ditunjukkan pada gambar berikut.

Pada akhirnya, klik tombol 'Ok'.

System Variable

  • Di bawah Variabel sistem, klik dua kali pada Path seperti yang ditunjukkan pada layar berikut.

  • Anda akan mendapatkan jendela Edit System Variable seperti yang ditunjukkan pada gambar berikut. Tambahkan jalur folder Node.js di bidang Nilai Variabel sebagai C: \ Program Files \ nodejs \ dan klik 'Ok' seperti yang ditunjukkan pada tangkapan layar berikut.

Step 4- Buka command prompt di sistem Anda dan masukkan perintah berikut. Ini akan menampilkan versi Node.js yang diinstal.

node -v

Step 5- Pada prompt perintah, masukkan perintah berikut untuk menampilkan versi npm (manajer paket Node.js) yang digunakan untuk menginstal modul. Ini akan menampilkan versi Node.js yang diinstal.

npm -v

Step 6- Pada prompt perintah, masukkan perintah berikut untuk menginstal Gulp. Menambahkan tanda “-g” memastikan Gulp tersedia secara global untuk proyek apa pun.

npm install gulp -g

Step 7 - Untuk memverifikasi bahwa Gulp telah berhasil diinstal, masukkan perintah berikut untuk menampilkan versi Gulp.

gulp -v

Dalam bab ini, Anda akan mengenal beberapa hal mendasar yang terkait dengan Gulp.

Apa itu Sistem Bangun?

Sistem Bangun disebut sebagai kumpulan tugas (secara kolektif disebut sebagai task runners), yang mengotomatiskan pekerjaan berulang.

Berikut adalah daftar beberapa tugas yang dapat ditangani menggunakan sistem build -

  • Kompilasi CSS dan JavaScript praproses.
  • Minifikasi file untuk mengurangi ukurannya.
  • Penggabungan file menjadi satu.
  • Memicu server untuk memuat ulang otomatis.
  • Pembuatan versi penerapan untuk menyimpan file yang dihasilkan di satu lokasi.

Dalam alur kerja front-end modern, sistem build bekerja dengan 3 komponen -

  • Manajer paket
  • Preprocessors
  • Pelari tugas dan alat pembangunan

Manajer Paket

Ini digunakan untuk mengotomatiskan peningkatan instalasi, penghapusan dependensi yang diperlukan, perpustakaan bersih, dan paket yang digunakan dalam lingkungan pengembangan. Contoh untuk manajer paket adalahbower dan npm.

Praprosesor

Preprocessor sangat berguna untuk alur kerja modern yang efisien dengan menambahkan sintaks yang dioptimalkan dan fitur tambahan yang dikompilasi ke dalam bahasa aslinya.

Beberapa praprosesor yang populer adalah -

  • CSS - SASS, LESS dan Stylus.

  • JS - CoffeeScript, LiveScript, TypeScript, dll.

  • HTML - Penurunan harga, HAML, Slim, Jade, dll.

Pelari Tugas

Pelari tugas mengotomatiskan tugas seperti konversi SASS ke CSS, mengecilkan file, mengoptimalkan gambar, dan banyak tugas lain yang digunakan dalam alur kerja pengembangan. Gulp adalah salah satu pelari tugas di lingkungan kerja front-end modern dan berjalan di Node.

Menyiapkan Proyek Anda

Untuk mengatur proyek Anda di komputer Anda, buat folder bernama "kerja" misalnya. Folder kerja berisi sub-folder dan file berikut -

  • Src - Lokasi file dan folder sumber HTML yang telah diproses sebelumnya.

    • Images - Berisi gambar yang tidak dikompresi.

    • Scripts - Berisi beberapa file skrip yang telah diproses sebelumnya.

    • Styles - Berisi beberapa file CSS yang telah diproses sebelumnya.

  • Build - Folder ini akan dibuat secara otomatis yang berisi file produksi.

    • Images - Berisi gambar terkompresi.

    • Scripts - File skrip tunggal yang berisi kode yang diperkecil.

    • Styles - File CSS tunggal yang berisi kode yang diperkecil.

  • gulpfile.js - Ini adalah file konfigurasi, yang digunakan untuk menentukan tugas kita.

Pada bab sebelumnya, Anda telah mempelajari tentang instalasi Gulp dan dasar-dasar Gulp yang mencakup sistem build Gulp, manajer paket, pelari tugas, struktur Gulp, dll.

Dalam bab ini, kita akan melihat dasar-dasar untuk mengembangkan aplikasi, yang meliputi:

  • Mendeklarasikan dependensi yang diperlukan
  • Membuat tugas untuk dependensi
  • Menjalankan tugas
  • Menonton tugas

Deklarasi Dependensi

Saat Anda menginstal plugin untuk aplikasi, Anda perlu menentukan dependensi untuk plugin tersebut. Dependensi ditangani oleh manajer paket seperti bower dan npm.

Mari kita ambil satu plugin bernama gulp-imageminuntuk menentukan dependensi untuknya di file konfigurasi. Plugin ini dapat digunakan untuk mengompres file gambar dan dapat diinstal menggunakan baris perintah berikut -

npm install gulp-imagemin --save-dev

Anda dapat menambahkan dependensi ke file konfigurasi Anda seperti yang ditunjukkan pada kode berikut.

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

Baris di atas menyertakan plug-in dan itu termasuk sebagai objek bernama imagemin.

Membuat Tugas untuk Dependensi

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.

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 berada 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 disalin ke folder build dengan memanggildest metode dengan argumen, yang mewakili direktori target.

Menjalankan Tugas

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

gulp imagemin

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

C:\work>gulp imagemin
[16:59:09] Using gulpfile C:\work\gulpfile.js
[16:59:09] Starting 'imagemin'...
[16:59:09] Finished 'imagemin' after 19 ms
[16:59:09] gulp-imagemin: Minified 2 images (saved 80.81 kB - 16.9%)

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

Metode Tonton digunakan untuk memantau file sumber Anda. Ketika ada perubahan pada file sumber, arloji akan menjalankan tugas yang sesuai. Anda dapat menggunakan tugas 'default' untuk melihat perubahan pada file HTML, CSS, dan JavaScript.

Perbarui Tugas Default

Di bab sebelumnya, Anda telah mempelajari cara menelan menggabungkan tugas menggunakan tugas default. Kami menggunakan gulp-minify-css, gulp-autoprefixer dan gulp-concatplugins, dan membuat tugas gaya untuk memperkecil file CSS.

Untuk melihat file CSS, kita perlu memperbarui tugas 'default' seperti yang ditunjukkan pada kode berikut:

gulp.task('default', ['styles'], function() {
   // watch for CSS changes
   gulp.watch('src/styles/*.css', function() {
      // run styles upon changes
      gulp.run('styles');
   });
});

Semua file CSS di bawah work/src/styles/ folder akan diawasi dan setelah perubahan dilakukan pada file-file ini, tugas gaya akan dijalankan.

Jalankan Tugas Default

Jalankan tugas 'default' menggunakan perintah berikut.

gulp

Setelah menjalankan perintah di atas, Anda akan menerima output berikut.

C:\work>gulp
[17:11:28] Using gulpfile C:\work\gulpfile.js
[17:11:28] Starting 'styles'...
[17:11:28] Finished 'styles' after 22 ms
[17:11:28] Starting 'default'...
[17:11:28] Finished 'default' after 21 ms

Setiap kali ada perubahan yang dilakukan pada file CSS, Anda akan menerima keluaran berikut.

C:\work>gulp
[17:11:28] Using gulpfile C:\work\gulpfile.js
[17:11:28] Starting 'styles'...
[17:11:28] Finished 'styles' after 22 ms
[17:11:28] Starting 'default'...
[17:11:28] Finished 'default' after 21 ms
gulp.run() has been deprecated. Use task dependencies or gulp.watch task 
   triggering instead.
[17:18:46] Starting 'styles'...
[17:18:46] Finished 'styles' after 5.1 ms

Proses Tonton akan tetap aktif dan menanggapi perubahan Anda. Anda bisa menekanCtrl+Cuntuk menghentikan proses pemantauan dan kembali ke baris perintah.

Live Reload menentukan perubahan dalam sistem file. BrowserSyncdigunakan untuk melihat semua file HTML dan CSS di direktori CSS dan melakukan pemuatan ulang langsung ke halaman di semua browser, setiap kali file diubah. BrowserSync membuat alur kerja lebih cepat dengan menyinkronkan URL, interaksi, dan perubahan kode di beberapa perangkat.

Menginstal Plugin BrowserSync

Plugin BrowserSync menyediakan injeksi CSS lintas browser dan dapat diinstal menggunakan perintah berikut.

npm install browser-sync --save-dev

Mengonfigurasi Plugin BrowserSync

Untuk menggunakan plugin BrowserSync, Anda perlu menulis dependensi di file konfigurasi Anda seperti yang ditunjukkan pada perintah berikut.

var browserSync = require('browser-sync').create();

Anda perlu membuat tugas untuk BrowserSync agar bekerja dengan server menggunakan Gulp. Karena Anda menjalankan server, Anda perlu menelepon BrowserSync tentang root server Anda. Di sini, kami menggunakan direktori dasar sebagai 'build'.

gulp.task('browserSync', function() {
   browserSync.init({
      server: {
         baseDir: 'build'
      },
   })
})

Anda juga dapat memasukkan gaya baru ke dalam browser menggunakan tugas berikut untuk file CSS.

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

Sebelum membuat tugas untuk BrowserSync, Anda perlu menginstal plugin menggunakan manajer paket dan menulis dependensi di file konfigurasi Anda seperti yang dijelaskan dalam bab ini .

Setelah Anda selesai dengan konfigurasi, jalankan BrowserSync dan watchTask untuk terjadinya efek reload langsung. Alih-alih menjalankan dua baris perintah secara terpisah, kami akan menjalankannya bersama dengan menambahkan browserSynctask bersama dengan watchTask seperti yang ditunjukkan pada kode berikut.

gulp.task('default', ['browserSync', 'styles'], function (){
   gulp.watch('src/styles/*.css', ['styles']);
});

Jalankan perintah berikut di direktori project Anda untuk menjalankan tugas gabungan di atas.

gulp

Setelah menjalankan tugas menggunakan perintah di atas, Anda akan mendapatkan hasil berikut di command prompt.

C:\project>gulp
[13:01:39] Using gulpfile C:\project\gulpfile.js
[13:01:39] Starting 'browserSync'...
[13:01:39] Finished 'browserSync' after 20 ms
[13:01:39] Starting 'styles'...
[13:01:39] Finished 'styles' after 21 ms
[13:01:39] Starting 'default'...
[13:01:39] Finished 'default' after 15 ms
[BS] 1 file changed (style.css)
[BS] Access URLs:
 ------------------------------------
       Local: http://localhost:3000
    External: http://192.168.1.4:3000
 ------------------------------------
          UI: http://localhost:3001
 UI External: http://192.168.1.4:3001
 ------------------------------------
[BS] Serving files from: build

Ini akan membuka jendela browser dengan URL http://localhost:3000/. Setiap perubahan yang dilakukan pada file CSS akan terlihat di command prompt dan browser memuat ulang secara otomatis dengan gaya yang diubah.

Di bab ini, Anda akan mempelajari cara mengoptimalkan CSS dan JavaScript. Pengoptimalan diperlukan untuk menghapus data yang tidak perlu (misalnya spasi dan karakter yang tidak digunakan) dari file sumber. Ini mengurangi ukuran file dan memungkinkan mereka memuat lebih cepat

Instal Plugin untuk Mengoptimalkan CSS dan JavaScript

Buka direktori "kerja" dari baris perintah Anda dan instal plugin "gulp-uglify", "gulp-minify-css" dan "gulp-concat" dengan menggunakan perintah berikut -

npm install gulp-uglify gulp-minify-css gulp-concat

Deklarasikan Dependensi dan Buat Tugas

Di file konfigurasi Anda gulpfile.js, deklarasikan terlebih dahulu dependensi seperti yang ditunjukkan pada kode berikut.

var gulp = require('gulp');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var minify = require('gulp-minify-css');

Selanjutnya, Anda perlu membuat tugas untuk mengoptimalkan CSS dan JavaScript seperti yang ditunjukkan pada kode berikut.

gulp.task('js', function(){
   gulp.src('src/scripts/*.js')
   .pipe(concat('script.js'))
   .pipe(uglify())
   .pipe(gulp.dest('build/scripts/'));
});

gulp.task('css', function(){
   gulp.src('src/styles/*.css')
   .pipe(concat('styles.css'))
   .pipe(minify())
   .pipe(gulp.dest('build/styles/'));
});

gulp.task('default',['js','css'],function(){
});

Itu js tugas akan menerima .js file dari src/scripts/map. Ini menggabungkan dan menggandakanjs file, lalu menghasilkan build/scripts/script.js mengajukan.

Itu CSS tugas akan menerima .css file dari src/styles/map. Ini menggabungkan dan meminimalkanCSS file, lalu menghasilkan build/styles/styles.css mengajukan.

Jalankan Tugas

File konfigurasi sudah disiapkan dan siap dijalankan. Gunakan perintah berikut untuk menjalankan tugas.

gulp

Saat menjalankan tugas menggunakan perintah di atas, Anda akan menerima hasil berikut di prompt perintah.

C:\work>gulp
[13:16:34] Using gulpfile C:\work\gulpfile.js
[13:16:34] Starting 'js'...
[13:16:34] Finished 'js' after 24 ms
[13:16:34] Starting 'css'...
[13:16:34] Finished 'css' after 6.05 ms
[13:16:34] Starting 'default'...
[13:16:34] Finished 'default' after 5.04 μs

Dalam bab ini, Anda akan mempelajari cara mengoptimalkan gambar. Mengoptimalkan akan mengurangi ukuran gambar dan membantu dalam memuat lebih cepat.

Instal Plugin untuk Mengoptimalkan Gambar

Pergi ke direktori "work" dari baris perintah Anda dan instal plugin "gulp-changes" dan "gulp-imagemin" dengan menggunakan perintah berikut.

npm install gulp-changed --save-dev
npm install gulp-imagemin --save-dev

Deklarasikan Dependensi dan Buat Tugas

Di file konfigurasi Anda gulpfile.js, pertama-tama deklarasikan dependensi seperti yang ditunjukkan pada perintah berikut.

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

Selanjutnya, Anda perlu membuat tugas untuk mengoptimalkan gambar seperti yang ditunjukkan pada kode berikut.

gulp.task('imagemin', function() {
   var imgSrc = 'src/images/*.+(png|jpg|gif)',
   imgDst = 'build/images';
   
   gulp.src(imgSrc)
   .pipe(changed(imgDst))
   .pipe(imagemin())
   .pipe(gulp.dest(imgDst));
});

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

Itu imagemintugas akan menerima gambar png, jpg dan gif dari folder src / images / dan mengecilkannya sebelum menulisnya ke tujuan. Ituchanged()memastikan bahwa hanya file baru yang diteruskan setiap kali untuk meminimalkan. The tegukan-berubah Plugin hanya akan memproses file baru dan karenanya dimanfaatkan waktu yang berharga.

Jalankan Tugas

File konfigurasi sudah disiapkan dan siap dijalankan. Gunakan perintah berikut untuk menjalankan tugas.

gulp

Saat menjalankan tugas menggunakan perintah di atas, Anda akan menerima hasil berikut di prompt perintah.

C:\work>gulp
[15:55:49] Using gulpfile C:\work\gulpfile.js
[15:55:49] Starting 'imagemin'...
[15:55:49] Finished 'imagemin' after 23 ms
[15:55:49] Starting 'default'...
[15:55:49] Finished 'default' after 23 μs
[15:55:54] gulp-imagemin: Minified 1 images (saved 558.3 kB - 8.3%)

Gulp menyediakan beberapa plugin berguna untuk bekerja dengan HTML & CSS, JavaScript, Grafik dan beberapa hal lain seperti yang dijelaskan dalam tabel berikut.

Plugin HTML & CSS

Sr.No. Plugin & Deskripsi
1 autoprefixer

Ini secara otomatis menyertakan awalan ke properti CSS.

2 gulp-browser-sync

Ini digunakan untuk menonton semua file HTML dan CSS di direktori CSS dan melakukan reload langsung ke halaman di semua browser, setiap kali file diubah

3 gulp-useref

Ini digunakan untuk mengganti referensi ke skrip atau stylesheet yang tidak dioptimalkan.

4 gulp-email-design

Ini menciptakan template email HTML yang mengubah gaya CSS menjadi sebaris.

5 gulp-uncss

Ini mengoptimalkan file CSS dan menemukan gaya yang tidak digunakan dan digandakan.

6 gulp-csso

Ini adalah pengoptimal CSS, yang meminimalkan file CSS sehingga ukuran file menjadi lebih kecil.

7 gulp-htmlmin

Ini meminimalkan file HTML.

8 gulp-csscomb

Ini digunakan untuk membuat pemformat gaya untuk CSS.

9 gulp-csslint

Ini menentukan linter CSS.

10 gulp-htmlhint

Ini menentukan validator HTML.

Plugin JavaScript

Sr.No. Plugin & Deskripsi
1 gulp-autopolyfiller

Ini sama seperti autoprefixer yang menyertakan polyfill yang diperlukan untuk JavaScript.

2 gulp-jsfmt

Ini digunakan untuk mencari potongan kode tertentu.

3 gulp-jscs

Ini digunakan untuk memeriksa gaya kode JavaScript.

4 gulp-modernizr

Ini menentukan fitur HTML, CSS, dan JavaScript yang ditawarkan browser pengguna.

5 gulp-express

Ini mulai menelan server web express.js.

6 gulp-requirejs

Ini menggunakan require.js untuk menggabungkan modul AMD require.js menjadi satu file.

7 gulp-plato

Ini menghasilkan laporan analisis kompleksitas.

8 gulp-complexity

Ini menganalisis kompleksitas dan pemeliharaan kode.

9 fixmyjs

Ini memperbaiki hasil JSHint.

10 gulp-jscpd

Ini digunakan sebagai detektor salin / tempel untuk kode sumber.

11 gulp-jsonlint

Ini adalah validator JSON.

12 gulp-uglify

Ini mengecilkan file JavaScript.

13 gulp-concat

Ini menggabungkan file CSS.

Uji Unit Plugin

Sr.No. Plugin & Deskripsi
1 gulp-nodeunit

Ini menjalankan tes unit node dari Gulp.

2 gulp-jasmine

Ini digunakan untuk melaporkan masalah yang terkait dengan output.

3 gulp-qunit

Ini menyediakan output konsol dasar untuk tes QUnit dan menggunakan modul node PhantomJS dan plugin QUnit pelari PhantomJS.

4 gulp-mocha

Ini menentukan pembungkus tipis di sekitar Mocha dan menjalankan tes Mocha.

5 gulp-karma

Ini sudah tidak digunakan lagi di Gulp.

Plugin Grafik

Sr.No. Plugin & Deskripsi
1 gulpicon

Ini menghasilkan sprite dari SVG dan mengubahnya menjadi PNG.

2 gulp-iconfont

Ini digunakan dengan font web untuk membuat file WOFF, EOT, TTF dari SVG.

3 gulp-imacss

Ini mengubah file gambar menjadi URI data dan menempatkannya ke dalam satu file CSS.

4 gulp-responsive

Ini menghasilkan gambar responsif untuk perangkat yang berbeda

5 gulp-sharp

Ini digunakan untuk mengubah dan mengubah ukuran orientasi dan latar belakang gambar.

6 gulp-svgstore

Ini menggabungkan file SVG menjadi satu dengan elemen <symbol>.

7 gulp-imagemin & gulp-tinypng

Ini digunakan untuk mengompresi gambar seperti PNG, JPEG, GIF, SVG.

8 gulp-spritesmith

Ini digunakan untuk membuat spritesheet dari kumpulan gambar dan variabel CSS.

Plugin Penyusun

Sr.No. Plugin & Deskripsi
1 gulp-less

Ini menyediakan plugin KURANG untuk Gulp.

2 gulp-sass

Ini menyediakan plugin SASS untuk Gulp.

3 gulp-compass

Ini menyediakan plugin kompas untuk Gulp.

4 gulp-stylus

Ini digunakan untuk menyimpan stylus di CSS.

5 gulp-coffee

Ini menyediakan plugin coffeescript untuk Gulp.

6 gulp-handlebars

Ini menyediakan plugin setang untuk Gulp.

7 gulp-jst

Ini menyediakan template garis bawah di JST.

8 gulp-react

Ini menentukan template Facebook React JSX ke dalam JavaScript.

9 gulp-nunjucks

Ini menentukan template Nunjucks di JST.

10 gulp-dustjs

Ini menentukan template Debu di JST.

11 gulp-angular-templatecache

Ini menentukan template AngularJS di templateCache.

Plugin Lainnya

Plugin gulp-clean menghapus file dan folder dan plugin gulp-copy menyalin file dari sumber ke tujuan baru.

Sr.No. Plugin & Deskripsi
1 gulp-grunt

Ini menjalankan tugas Grunt dari Gulp

2 gulp-watch

Ia melihat file setiap kali ada perubahan.

3 gulp-notify

Ini memberi tahu pesan kesalahan setiap kali tugas gagal.

4 gulp-git

Ini memungkinkan untuk menggunakan perintah Git.

5 gulp-jsdoc

Ini membuat dokumentasi JavaScript untuk Gulp.

6 gulp-rev

Ini menyediakan revisi aset statis ke nama file.

7 gulp-bump

Ini meningkatkan versi dalam paket JSON.

8 gulp-bower-files

Ini digunakan untuk menyuntikkan paket bower.

9 gulp-removelogs

Ini menghapus pernyataan console.log.

10 gulp-preprocess

Itu preprocesses HTML, JavaScript dan file lain berdasarkan konteks atau konfigurasi lingkungan.

11 gulp-duration

Ini menentukan durasi untuk tugas Gulp.

12 gulp-changed & gulp-newer

Ini menjalankan file yang dimodifikasi dan file yang lebih baru.

13 gulp-connect

Ini digunakan untuk menjalankan server web dengan LiveReload.

14 gulp-shell

Ini menjalankan perintah Shell.

15 gulp-ssh

Ini terhubung dengan menggunakan tugas SSH dan SFTP.

16 gulp-zip

Ini memampatkan file dan folder.

17 gulp-clean & gulp-copy
18 gulp-filesize

Ini menentukan ukuran file dalam format yang dapat dibaca manusia.

19 gulp-util

Ini menyediakan utilitas untuk plugin gulp.

Di bab ini, Anda akan mempelajari cara membersihkan file yang dihasilkan. Saat kami membuat file secara otomatis, pastikan bahwa file yang tidak diperlukan harus dihapus sebelum menjalankan build Anda. Prosedur ini disebutcleaning. Itudel plugin dapat digunakan untuk tujuan ini.

Menginstal Plugin del

Di baris perintah Anda, instal plugin dengan memasukkan perintah berikut.

npm install del --save-dev

Deklarasikan Dependensi dan Buat Tugas

Di file konfigurasi Anda gulpfile.js, nyatakan dependensi seperti yang ditunjukkan pada perintah berikut.

var del = require('del');

Selanjutnya, buat tugas seperti yang ditunjukkan pada kode berikut.

gulp.task('clean:build', function() {
   return del.sync('build');
});

Tugas di atas akan membersihkan seluruh build. Tugas bersih membersihkan semua gambar yang ditangkap dan menghapus file lama yang ada di build.

Anda hanya dapat membersihkan file atau folder tertentu dan membiarkan beberapa di antaranya tidak tersentuh seperti yang diilustrasikan dalam kode berikut.

gulp.task('clean:build', function() {
   //return del.sync('build');
   return del([
      'build/temp/',
      // instructs to clean temp folder
      '!build/package.json'
      // negate to instruct not to clean package.json file ]);
});

Dalam tugas di atas, hanya file temp folder akan dibersihkan pergi package.json tak tersentuh.