- именование классов по БЭМ
- используется БЭМ-структура
- используется препроцессор SCSS
- используется транспайлер Babel для поддержки современного JavaScript (ES6) в браузерах
- используется Webpack для сборки JavaScript-модулей
- используется CSS-сетка smart-grid на основе Bootstrap для быстрой адаптивной вёрстки
- используется жёсткий кодгайд
- установите NodeJS (если требуется) и Yarn
- скачайте сборку с помощью Git:
git clone https://github.com/andreyalexeich/gulp-scss-starter.git - установите
gulpглобально:yarn global add gulp-cli - перейдите в скачанную папку со сборкой:
cd gulp-scss-starter - скачайте необходимые зависимости:
yarn - чтобы начать работу, введите команду:
yarn run dev(режим разработки) - чтобы собрать проект, введите команду
yarn run build(режим сборки)
Если вы всё сделали правильно, у вас должен открыться браузер с локальным сервером. Режим сборки предполагает оптимизацию проекта: сжатие изображений, минифицирование CSS и JS-файлов для загрузки на сервер.
gulp-scss-starter
├── dist
├── gulp-tasks
├── src
│ ├── blocks
│ ├── fonts
│ ├── img
│ ├── js
│ ├── styles
│ ├── views
│ └── .htaccess
├── gulpfile.babel.js
├── webpack.config.js
├── package.json
├── .babelrc.js
├── .bemrc.js
├── .eslintrc.json
├── .stylelintrc
├── .stylelintignore
└── .gitignore
- Корень папки:
.babelrc.js— настройки Babel.bemrc.js— настройки БЭМ.eslintrc.json— настройки ESLint.gitignore– запрет на отслеживание файлов Git'ом.stylelintrc— настройки Stylelint.stylelintignore– запрет на отслеживание файлов Stylelint'омgulpfile.babel.js— настройки Gulpwebpack.config.js— настройки Webpackpackage.json— список зависимостей
- Папка
src- используется во время разработки:- БЭМ-блоки:
src/blocks - шрифты:
src/fonts - изображения:
src/img - JS-файлы:
src/js - страницы сайта:
src/views/pages - SCSS-файлы:
src/styles - HTML-файлы:
src/views - конфигурационный файл веб-сервера Apache с настройками gzip (сжатие без потерь):
src/.htaccess
- БЭМ-блоки:
- Папка
dist- папка, из которой запускается локальный сервер для разработки (при запускеyarn run dev) - Папка
gulp-tasks- папка с Gulp-тасками
yarn run lint:style- проверить SCSS-файлы. Для VSCode необходимо установить плагин. Для WebStorm или PHPStorm необходимо включить Stylelint вLanguages & Frameworks - Style Sheets - Stylelint(ошибки будут исправлены автоматически при сохранении файла)yarn run lint:style --fix- исправить ошибки в SCSS-файлахyarn run dev- запуск сервера для разработки проектаyarn run build- собрать проект с оптимизацией без запуска сервераyarn run build views- скомпилировать Pug-файлыyarn run build styles- скомпилировать SCSS-файлыyarn run build scripts- собрать JS-файлыyarn run build images- собрать изображенияyarn run build webp- сконвертировать изображения в формат.webpyarn run build sprites- собрать спрайтыyarn run build fonts- собрать шрифтыyarn run build favicons- собрать фавиконкиyarn run build gzip- собрать конфигурацию Apache
- каждый БЭМ-блок имеет свою папку внутри
src/blocks/modules - папка одного БЭМ-блока содержит в себе один HTML-файл, один SCSS-файл и один JS-файл (если у блока используется скрипт)
- HTML-файл блока импортируется в файл
src/views/index.html(или в необходимый файл страницы, откуда будет вызываться блок) - SCSS-файл блока импортируется в файл
src/blocks/modules/_modules.scss - JS-файл блока импортируется в
src/js/import/modules.js
- HTML-файл блока импортируется в файл
Пример структуры папки с БЭМ-блоком:
blocks
├── modules
│ ├──header
│ │ ├── header.html
│ │ ├── header.js
│ │ ├── header.scss
Чтобы вручную не создавать соответствующие папку и файлы, достаточно в консоли прописать команду bem create my-block - для создания папки БЭМ-блока, где my-block - имя БЭМ-блока
- страницы проекта находятся в папке
src/views/pages- главная страница:
src/views/index.html
- главная страница:
- шрифты находятся в папке
src/fonts- используйте форматы
.woffи.woff2 - шрифты подключаются в файл
src/styles/base/_fonts.scss - сконвертировать локальные шрифты можно с помощью данного сервиса
- используйте форматы
- изображения находятся в папке
src/img- изображение для генерации фавиконок должно находиться в папке
src/img/faviconи иметь размер не менее1024px x 1024px - изображения автоматически конвертируются в формат
.webp. Подробная информация по использованию тут.
- изображение для генерации фавиконок должно находиться в папке
- все сторонние библиотеки устанавливаются в папку
node_modules- для их загрузки воспользуйтеcь командой
yarn add package_name - для подключения JS-файлов библиотек импортируйте их в самом начале JS-файла БЭМ-блока (то есть тот БЭМ-блок, который использует скрипт), например:
import $ from "jquery";
- для подключения стилевых файлов библиотек импортируйте их в файл
src/styles/vendor/_libs.scss - JS-файлы и стилевые файлы библиотек самостоятельно изменять нельзя
- для их загрузки воспользуйтеcь командой
- по пути
src/js/importсоздать папкуpages - в папке
pagesсоздать js-файл для страницы, например,pageA.js, и импортировать туда библиотеку, которая будет использоваться только на этой странице- аналогично проделать шаг для дополнительных страниц
- в файле
webpack.config.jsв точку входа добавить js-файлы страниц, пример:
entry: {
main: "./src/js/index.js",
pageA: "./src/js/import/pages/pageA.js",
pageB: "./src/js/import/pages/pageB.js"
}- подключить скомпилированные js-файлы на необходимых страницах
В сборщик включена 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);
}
}Используйте эту сборку.
Сообщайте мне о багах, ставьте звёздочку в правом верхнем углу, задонатьте мне на пиво 🍺
- ВКонтакте: @andreyalexeich
- Telegram: @andreyalexeich