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.