Gulp - Mengoptimalkan CSS dan JavaScript

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, pertama-tama nyatakan 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