Gulp - Оптимизация CSS и JavaScript

В этой главе вы узнаете, как оптимизировать CSS и JavaScript. Оптимизация требуется для удаления ненужных данных (например, пробелов и неиспользуемых символов) из исходных файлов. Это уменьшает размер файлов и позволяет им загружаться быстрее.

Установите плагины для оптимизации CSS и JavaScript

Перейдите в каталог «work» из командной строки и установите плагины «gulp-uglify», «gulp-minify-css» и «gulp-concat», используя следующую команду:

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

Объявить зависимости и создать задачи

В вашем файле конфигурации gulpfile.js, сначала объявите зависимости, как показано в следующем коде.

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

Затем вам нужно создать задачи для оптимизации CSS и JavaScript, как показано в следующем коде.

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(){
});

В js задача будет принимать .js файлы из src/scripts/папка. Он объединяет и искажаетjs файлы, затем производит build/scripts/script.js файл.

В CSS задача примет .css файлы из src/styles/папка. Он объединяет и минимизируетCSS файлы, затем производит build/styles/styles.css файл.

Выполнить задачи

Файл конфигурации настроен и готов к выполнению. Используйте следующую команду для запуска задачи.

gulp

Запустив задачу с помощью указанной выше команды, вы получите следующий результат в командной строке.

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