- сборка предназначена для автоматизации задач в повседневной front-end разработке
- именование классов по БЭМ
- использование препроцессора Pug
- использование препроцессора SCSS
- использование транспайлера Babel для поддержки современного JavaScript (ES6) в браузерах
- использование Webpack для сборки JavaScript-модулей
- использование CSS-сетки smart-grid для быстрой адаптивной вёрстки
- установите Yarn
Yarn - это современная альтернатива npm. Yarn работает с тем же файлом
package.json
и так же скачивает необходимые модули в папкуnode_modules
, но делает это намного быстрее.
- скачайте сборку:
git clone /~https://github.com/andreyalexeich/gulp-pug-starter.git
- установите
gulp
глобально:yarn global add gulp-cli
- перейдите в скачанную папку со сборкой:
cd gulp-pug-starter
- скачайте необходимые зависимости:
yarn
- чтобы начать работу, введите команду:
yarn run dev
(режим разработки) - чтобы собрать проект, введите команду
yarn run build
(режим сборки)
Если вы всё сделали правильно, у вас должен открыться браузер с локальным сервером. Режим сборки предполагает оптимизацию проекта: сжатие изображений, минифицирование CSS и JS-файлов для загрузки на сервер.
gulp-pug-starter
├── dist
├── src
│ ├── blocks
│ ├── fonts
│ ├── img
│ ├── js
│ ├── pages
│ ├── styles
│ ├── views
│ └── .htaccess
├── gulpfile.babel.js
├── webpack.config.js
├── package.json
├── .babelrc.js
├── .bemrc.js
├── .eslintrc.json
└── .gitignore
- Корень папки:
.babelrc.js
— настройка ES6.bemrc.js
— настройка БЭМ.eslintrc.json
— настройка ESLint.gitignore
– запрет на отслеживание файлов Git'омgulpfile.babel.js
— настройки Gulpwebpack.config.js
— настройки Webpackpackage.json
— список зависимостей
- Папка
src
- используется во время разработки:- БЭМ-блоки и компоненты:
src/blocks
- шрифты:
src/fonts
- изображения:
src/img
- JS-файлы:
src/js
- страницы сайта:
src/pages
- SCSS-файлы:
src/styles
- Pug-файлы:
src/views
- конфигурационный файл веб-сервера Apache с настройками gzip (сжатие без потерь):
src/.htaccess
- БЭМ-блоки и компоненты:
- Папка
dist
- папка, из которой запускается локальный сервер для разработки (при запускеyarn run dev
)
- придерживайтесь изначальной структуры папок и файлов
- придерживайтесь компонентного подхода к разработке сайтов
- каждый БЭМ-блок имеет свою папку внутри
src/blocks/modules
- папка одного БЭМ-блока содержит в себе один Pug-файл, один SCSS-файл и один JS-файл (если у блока используется скрипт)
- Pug-файл блока импортируется в файл
src/views/index.pug
- SCSS-файл блока импортируется в файл
src/blocks/modules/_modules.scss
, который в свою очередь импортируется в файлsrc/styles/main.scss
- JS-файл блока импортируется в
src/js/import/modules.js
, который в свою очередь импортируется в файлsrc/js/index.js
- каждый БЭМ-блок имеет свою папку внутри
- компоненты (например, иконки, кнопки) оформляются в Pug с помощью примесей
- каждый компонент имеет свою папку внутри
src/blocks/components
- папка одного компонента содержит в себе один Pug-файл, один SCSS-файл и один JS-файл
- Pug-файл компонента импортируется в файл
src/views/layouts/default.pug
, который в свою очередь импортируется в файлsrc/views/index.pug
- SCSS-файл компонента импортируется в файл
src/blocks/components/_components.scss
, который в свою очередь импортируется в файлsrc/styles/main.scss
- JS-файл компонента импортируется в файл
src/js/import/components.js
, который в свою очередь импортируется в файлsrc/js/index.js
- каждый компонент имеет свою папку внутри
- из всех SCSS-файлов компилируется только
main.scss
. Остальные стилевые файлы импортируются в него - страницы сайта находятся в папке
src/pages
- каждая страница (в том числе главная) наследует шаблон
src/views/layouts/default.pug
- главная страница:
src/views/index.pug
- каждая страница (в том числе главная) наследует шаблон
- шрифты находятся в папке
src/fonts
- изображения находятся в папке
src/img
- изображение для генерации фавиконок должно находиться в папке
src/img
и иметь размер не менее100px x 100px
- изображение для генерации фавиконок должно находиться в папке
- все сторонние библиотеки устанавливаются в папку
node_modules
- для их загрузки воспользуйтеcь командой
yarn add package_name
- для подключения JS-файлов библиотек импортируйте их в JS-файл БЭМ-блока (то есть тот БЭМ-блок, который использует скрипт), например:
import $ from "jquery";
- для подключения стилевых файлов библиотек импортируйте их в файл
src/styles/_libs.scss
(который в свою очередь импортируется в файлsrc/styles/main.scss
)
- для их загрузки воспользуйтеcь командой
- в вёрстку подключаются только минифицированные CSS и JS-файлы.
В сборке используется компонентный подход к разработке сайтов по методолгии БЭМ, когда каждый БЭМ-блок имеет свою папку, внутри которой находятся один Pug-файл, один SCSS-файл и один JS-файл (если у блока используется скрипт). Чтобы вручную не создавать соответствующие папку и файлы, достаточно в консоли прописать следующие команды:
bem create my-block
- для создания папки БЭМ-блока, гдеmy-block
- имя БЭМ-блокаbem create my-component -l src/blocks/components
для создания компонентаbem create my-component -l src/blocks/components && bem create my-block
- создать всё вместе
Для более удобного написания разметки по БЭМ используется плагин шорткатов для препроцессора Pug. Пример использования:
Pug
header.header
nav.menu
a(href="#")._logo Company
.list
a._item.-active(href="#") Home
a._item(href="#") News
a._item(href="#") Gallery
a._item(href="#") Partners
a._item(href="#") About
a._item(href="#") Contacts
h1._title Hello, World!
.myslider._myslider
._slide Content
._slide.-active Content
._slide Content
p._text Good weather
Результат
<header class="header">
<nav class="menu">
<a class="menu__logo" href="#">Company</a>
<div class="list">
<a class="list__item list__item--active" href="#">Home</a>
<a class="list__item" href="#">News</a>
<a class="list__item" href="#">Gallery</a>
<a class="list__item" href="#">Partners</a>
<a class="list__item" href="#">About</a>
<a class="list__item" href="#">Contacts</a>
</div>
</nav>
<h1 class="header__title">Hello, World!</h1>
<div class="myslider header__myslider">
<div class="myslider__slide">Content</div>
<div class="myslider__slide myslider__slide--active">Content</div>
<div class="myslider__slide">Content</div>
</div>
<p class="header__text">Good weather</p>
</header>
В сборщик включена CSS-сетка smart-grid от Дмитрия Лаврика. Она позволяет избавиться от лишних классов в разметке за счёт использования примесей в SCSS и ускоряет адаптивную вёрстку. Конфигурация уже настроена в соответствии с сеткой Bootstrap. Пример использования:
SCSS
.items{
@include row-flex();
@include md(justify-content, center);
.item{
@include col();
@include size(3);
@include size-md(5);
@include size-xs(10);
}
}
Результат
.items {
display: flex;
flex-wrap: wrap;
margin-left: -15px;
margin-right: -15px;
}
.items .item {
box-sizing: border-box;
margin-left: 15px;
margin-right: 15px;
word-wrap: break-word;
width: calc(100% / 12 * 3 - 30px);
}
@media screen and (max-width: 992px) {
.items {
justify-content: center;
}
.items .item {
width: calc(100% / 12 * 5 - 30px);
}
}
@media screen and (max-width: 576px) {
.items .item {
width: calc(100% / 12 * 10 - 30px);
}
}
В сборщик включена поддержка WebP. WebP — это формат графики, разработанный Google в 2010 году. Он был создан как альтернатива PNG и JPG и отличается от них гораздо меньшим размером при том же качестве изображения. Подробная информация по использованию тут.
Используйте эту сборку.
- ВКонтакте: @andreyalexeich
- Telegram: @andreyalexeich