Skip to content

Bladhard/gulp-new-project

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Сборка проекта на Gulp 4

Установка и работа с текущей сборкой

  • Установить node.js
  • Скачать или клонировать текущий репозиторий
  • Запустить в папке проекта консоль (в Windows через Shift + правый клик => Windows PowerShell)
  • Пишем команду npm i
  • Ожидаем установку всех зависимостей
  • Работа со сборкой
    • gulp — задача по умолчанию, позволяет вести разработку в текстовом редакторе и сразу видеть результат в окне браузера
    • gulp build — сборка проекта (минификация .css/.js файлов, сжатие графики, удаление лишних файлов, архивация проекта)
      • До команды в папке результатов а именно в js и style находятся script.min.js, style.min.js в обычном не сжатом состоянии, после эти файлы сжимаются и в конечном результате добавляются две не сжатые копии дубликаты script.js и style.js.
      • Также в папках js и style присувствуют папки map которые удаляться
      • В папке img если создавался svg sprite будет удалена папка symbol

Модули:

  • del - Удаление каталогов и файлов
  • browser-sync - Синхронизация кода с результатами в браузере
  • gulp - Сборщик Gulp
  • gulp-if - Помогает в сборке
  • gulp-zip - Архивируем проект в zip
  • gulp-changed - Позволяет обрабатывать только те файлы которые изменились
  • gulp-clean-css - Минификация и оптимизация CSS файлов
  • gulp-concat - Переименовывает файлы (Объединение нескольких файлов в один)
  • gulp-file-include - Объединяет файлы (использую для html)
  • gulp-plumber - Позволяет работать gulp после появления ошибки
  • gulp-notify - Показывает уведомление об ошибки
  • gulp-sourcemaps - Cоздает карту кода для консоли в браузере
  • gulp-fonter - Cоздает шрифт TTF из OTF-шрифта
  • gulp-ttf2woff - Cоздает шрифт WOFF из TTF-шрифта
  • gulp-ttf2woff2 - Cоздает шрифт WOFF2 из TTF-шрифта
  • gulp-svg-sprite - Создание SVG спрайтов
  • gulp-imagemin - Для сжатия изображений
  • webp-converter - Нужен для работы с webp версия 2.2.3!
  • gulp-webp - Преобразование изображения в формат файла webp
  • gulp-webp-html-fix - Автодополнение в html правил совместимости с webp
  • gulp-webpcss - Автодополнение в css правил совместимости с webp
  • gulp-datasrc-html - Автозамена в html, src, srcset на data-src, data-srcset
  • gulp-lqip-base64 - Автодополнение в html, изображений base64 по атрибуту data-src
  • smart-grid - Адаптивная верстка через css
  • gulp-less - Компиляция Less файлов
  • less-plugin-autoprefix - Добавляет префиксы в CSS код
  • gulp-group-css-media-queries - Группирует все медиа запросы в css в конце файла
  • webpack - Модульность в JS
  • webpack-stream - Webpack как поток для gulp
  • core-js - Включает в себя полифиллы для ECMAScript до 2021года
  • babel-loader - Этот пакет позволяет транспилировать файлы JavaScript с помощью Babel и webpack.
  • @babel/core - Ядро компилятора Babel
  • @babel/preset-env - Предустановка Babel для каждой среды

Работа с изображениями

gulp-settings.js

Настройка для работы с LazyLoading и изображениями формата webp

const settings = {
    webp: {
        webpHTML: false, // заменяет img на picture + делает копии картинок в webp формат
        webpCSS: false, // добавляет поддержку webp в css
    },
    lazyload: {
        dataHTML: false, // замена src, srcset на data-src, data-srcset
        lqipBase64: false, // добавлять Base64 миниатюры в img
    }
}

Настройки активируют следущии плагины

Результат true в webpHTML, dataHTML, lqipBase64

<!-- до -->
<img src="./img/img-8.jpg">
<!-- после -->
<picture>
    <source data-srcset="./img/img-8.webp" type="image/webp">
    <img data-src="./img/img-8.jpg" src="...">
</picture>

Автоматическое Формирование @font-face:

  • Названия шрифтов не должны иметь пробелов, использовать( -, _ )
  • Формат наименования шрифта должен быть такого типа: name-bold*.woff или name-bold*-italic.woff (Регистр не имеет значения)

Пример:

Banny-ExtraBoldRound-italic.woff

Результат:

Миксин Less

.font("Banny", "Banny-ExtraBoldRound-italic", "800", "italic");

Исходный код CSS

@font-face {
  font-family: Banny;
  font-display: swap;
  src: url(../fonts/Banny-ExtraBoldRound-italic.woff) format("woff");
  font-weight: 800;
  font-style: italic
}

Code JS

Функция определения font-weight по имени шрифта:

function checkWeight(fontname) {
    const lowCase = fontname.toLowerCase()
    const fontStyle = {
        thin: 100,
        extralight: 200,
        light: 300,
        regular: 400,
        medium: 500,
        semibold: 600,
        extrabold: 800,
        bold: 700,
        heavy: 700,
        black: 900,
    }
    for (let keys of Object.keys(fontStyle)) {
        if (lowCase.indexOf(keys) > -1) {
            if (lowCase.indexOf(keys)) {
                return fontStyle[keys]
            } else {
                return fontStyle[keys]
            }
        }
    }
    return 400
}

Функция определения всех параметров шрифта и передачи значений миксину:

function fontsStyle(done) {
    fs.writeFileSync(`${source_folder}/less/include/fonts.less`, '')
    fs.appendFileSync(source_folder + '/less/include/fonts.less', '// main: ./main.less\r\n\n')
    return fs.readdir(path.build.fonts, (err, items) => {
        if (items) {
            let c_fontname
            for (var i = 0; i < items.length; i++) {
                let fontname = items[i].split('.')
                fontname = fontname[0]
                let font = fontname.split(/[-_]/)[0]
                let weight = checkWeight(fontname.split(/[-_]/)[1])
                let style = fontname.split(/[-_]/)[2] || 'normal'
                console.log(`Шрифт ${fontname} готов! - ${font}, ${weight}, ${style}`)

                if (c_fontname != fontname) {
                    fs.appendFile(
                        source_folder + '/less/include/fonts.less',
                        `.font("${font}", "${fontname}", ${weight}, "${style}");\r\n`,
                        done
                    )
                }
                c_fontname = fontname
            }
        }
        done()
    })
}

Mixin Less

.font(@font_name, @file_name, @weight, @style) {
    @font-face {
        font-family: @font_name;
        font-display: swap;
        src: url("../fonts/@{file_name}.woff") format("woff"),
        url("../fonts/@{file_name}.woff2") format("woff2"); // по выбору
        font-weight: @weight;
        font-style: @style;
    }
}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published