Пакет предоставляет набор базовых ENB-технологий для сборки проектов, в основе которых лежит БЭМ-методология.
Основная задача базовых технологий — подготовить промежуточный результат для технологий, которые ничего не знают о методологии и о том, как устроен проект.
Большинство технологий в ENB ожидает на вход список файлов или директорий, а также информацию о требуемом порядке для их сборки.
$ npm install --save-dev enb-bem-techs
Для работы модуля требуется зависимость от пакета enb
версии 0.13.0
или выше.
Воспользуйтесь инструкцией по установке project-stub, чтобы создать БЭМ-проект, настроенный для сборки с помощью ENB.
Для создания проекта, подходящего под ваши задачи, ответьте на вопросы генератора БЭМ-проектов, основанного на Yeoman.
- enb-stylus — сборка
stylus
-файлов. - enb-autoprefixer — поддержка
autoprefixer
.
- enb-bh — сборка BH-шаблонов.
- enb-xjst — сборка BEMHTML и BEMTREE на основе
xjst
. - enb-bemxjst — сборка BEMHTML и BEMTREE на основе
bem-xjst
.
- enb-bem-examples — сборка БЭМ-примеров.
- enb-bem-docs — сборка БЭМ-документации.
- enb-bem-specs — сборка и запуск тестов для клиентского JavaScript.
- enb-bem-tmpl-specs — сборка и запуск тестов для БЭМ-шаблонов.
- enb-magic-platform — платформа и dev-сервер для сборки БЭМ-проектов.
- enb-borschik — поддержка
borschik
. - enb-modules — поддержка
ym
. - enb-diverse-js — поддержка паттерна
vanilla.js
+node.js
+browser.js
. - enb-bem-i18n — поддержка
BEM.I18N
.
- levels
- levelsToBemdecl
- bemjsonToBemdecl
- deps
- depsOld
- depsByTechToBemdecl
- files
- provideBemdecl
- provideDeps
- mergeBemdecl
- mergeDeps
- subtractDeps
Собирает информацию об уровнях переопределения проекта. Результат выполнения этой технологии необходим следующим технологиям:
levelsToBemdecl
deps
depsOld
files
Тип: String
. По умолчанию: ?.levels
.
Результирующий таргет.
Тип: String[] | Object[]
.
Список путей до уровней переопределения.
Каждый путь может быть задан абсолютным или относительно корня проекта.
Вместо строки может использоваться объект вида { path: 'path/to/level', check: false }
.
Поле path
является обязательным, а поле check
по умолчанию равно true
.
Значение check: false
используется для того, чтобы закэшировать содержимое уровня.
Если указать check: true
уровень будет сканироваться заново каждый раз при сборке, вне зависимости от наличия кэша.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.levels, { levels: [
// На проекте не нужно менять код внешних библиотек,
// достаточно один раз просканировать их уровни и использовать кэш.
{ path: 'libs/bem-core/common.blocks', check: false },
{ path: 'libs/bem-core/desktop.blocks', check: false },
// Уровни проекта нужно сканировать перед каждой сборкой.
{ path: 'desktop.blocks', check: true },
] }]);
Формирует BEMDECL-файл, состоящий из всех БЭМ-сущностей, найденных в указанных уровнях.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Результирующий BEMDECL-файл.
Тип: String
. По умолчанию: ?.levels
.
Таргет с интроспекцией уровней (результат сканирования levels
технологией).
var techs = require('enb-bem-techs');
nodeConfig.addTechs([
// Сканируем уровни проекта.
// Результат записываем в `?.levels`,
// т.к. опция `target` по умолчанию — `?.levels`.
[techs.levels, { levels: ['blocks'] }],
// Строим BEMDECL-файл по результатам сканирования уровней.
// Интроспекцию берём из `?.levels`,
// т.к. опция `source` по умолчанию — `?.levels`.
[techs.levelsToBemdecl]
]);
Формирует BEMDECL-файл из BEMJSON-файла.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Результирующий BEMDECL-файл.
Тип: String
. По умолчанию: ?.bemjson.js
.
Исходный BEMJSON-файл.
var techs = require('enb-bem-techs'),
provide = require('enb/techs/file-provider');
nodeConfig.addTechs([
// Предоставляет BEMJSON-файл, написанный вручную, для ENB.
// В опции `target` путь до BEMJSON-файла.
[provide, { target: '?.bemjson.js' }],
// Строим BEMDECL-файл по полученному BEMJSON-файлу.
// BEMJSON-файл берём из `?.bemjson.js`,
// т.к. опция `source` по умолчанию — `?.bemjson.js`.
[techs.bemjsonToBemdecl]
]);
Дополняет декларацию БЭМ-сущностей на основе информации из технологий зависимостей (deps.js
или deps.yaml
) БЭМ-сущностей.
Тип: String
. По умолчанию: ?.deps.js
.
Результирующий DEPS-файл.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Файл с декларацией БЭМ-сущностей.
Тип: String
. По умолчанию: ?.levels
.
Таргет с интроспекцией уровней (результат сканирования levels
технологией).
Раскрытие зависимостей по BEMDECL-файлу.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.deps, {
bemdeclFile: '?.bemdecl.js',
target: '?.deps.js'
}]);
Раскрытие зависимостей по DEPS-файлу.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.deps, {
bemdeclFile: 'source-decl.deps.js',
target: '?.deps.js'
}]);
Дополняет декларацию БЭМ-сущностей на основе информации из технологий зависимостей (deps.js
) БЭМ-сущностей.
Использует алгоритм, заимствованный из bem-tools.
Тип: String
. По умолчанию: ?.deps.js
.
Результирующий DEPS-файл.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Файл с декларацией БЭМ-сущностей.
Тип: String
. По умолчанию: ?.levels
.
Таргет с интроспекцией уровней (результат сканирования levels
технологией).
Тип: Boolean
. По умолчанию: false
.
Включает строгий режим раскрытия зависимостей: если будет найдена хотя бы одна циклическая зависимость mustDeps
(A ← B ← A), то сборка прекратится с ошибкой.
Раскрытие зависимостей по BEMDECL-файлу.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.depsOld, {
bemdeclFile: '?.bemdecl.js',
target: '?.deps.js'
}]);
Раскрытие зависимостей по DEPS-файлу.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.depsOld, {
bemdeclFile: 'source-decl.deps.js',
target: '?.deps.js'
}]);
Формирует BEMDECL-файл на основе зависимостей по технологиям (depsByTech). Такие зависимости описываются в deps.js
технологиях БЭМ-сущностей.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Результирующий BEMDECL-файл.
Тип: String
. Обязательная опция.
Имя технологии для которой собираются зависимости.
Тип: String
.
Имя технологии от которой зависит sourceTech
.
Тип: String
. По умолчанию: ?.files
.
Таргет со списоком deps.js
-файлов (результат технологии files
).
Тип: String[]
. По умолчанию: ['deps.js']
.
Суффиксы файлов с описанием зависимостей БЭМ-сущностей.
Частый случай, когда БЭМ-сущность в технологии клиенского JavaScript использует свою же технологию шаблонов.
button.deps.js
{
block: 'button'
tech: 'js' // sourceTech
shouldDeps: {
tech: 'bemhtml' // destTech
}
}
В большинстве случаев схема построения BEMDECL-файла по depsByTech
выглядит так:
(BEMJSON ->) BEMDECL (1) -> deps (2) -> files (3) -> BEMDECL (4)
- Получаем BEMDECL-файл (?.bemdecl.js).
- Дополняем декларацию БЭМ-сущностей из BEMDECL-файла и записываем результат в DEPS-файл (?.deps.js).
- Получаем упорядоченный список
deps.js
файлов (?.files.js). - Получаем BEMDECL-файл на основе зависимостей по технологиям (?.tech.bemdecl.js).
var techs = require('enb-bem-techs'),
provide = require('enb/techs/file-provider');
nodeConfig.addTechs([
[techs.levels, { levels: ['blocks'] }],
[provide, { target: '?.bemdecl.js' }], // (1) `?.bemdecl.js`
[techs.deps], // (2) `?.deps.js`
[techs.files], // (3) `?.files.js`
// Далее '?.bemhtml.bemdecl.js' можно использовать для сборки шаблонов,
// которые используются в клиенском JavaScript.
// Список `deps.js` файлов берём из `?.files`, т.к. опция filesTarget
// по умолчанию — `?.files`.
[techs.depsByTechToBemdecl, { // (4) `?.bemhtml.bemdecl.js`
target: '?.bemhtml.bemdecl.js',
sourceTech: 'js',
destTech: 'bemhtml'
}]
]);
Собирает список исходных файлов и директорий для сборки на основе декларации БЭМ-сущностей, а также результате сканирования уровней levels
технологией.
Предоставляет ?.files
и ?.dirs
таргеты.
Используется большинством технологиями в ENB (кроме базовых).
Тип: String
. По умолчанию: ?.files
.
Результирующий files
-таргет.
Тип: String
. По умолчанию: ?.dirs
.
Результирующий dirs
-таргет.
Тип: String
. По умолчанию: ?.deps.js
.
Исходная декларация БЭМ-сущностей.
Тип: String
. По умолчанию: ?.levels
.
Таргет с интроспекцией уровней (результат сканирования levels
технологией).
Формирование списка файлов и директорий по BEMDECL-файлу.
var techs = require('enb-bem-techs'),
provide = require('enb/techs/file-provider');
nodeConfig.addTechs([
[techs.levels, { levels: ['blocks'] }],
[provide, { target: '?.bemdecl.js' }]
[techs.files, { depsFile: '?.bemdecl.js' }]
]);
Формирование списка файлов и директорий по DEPS-файлу.
var techs = require('enb-bem-techs'),
provide = require('enb/techs/file-provider');
nodeConfig.addTechs([
[techs.levels, { levels: ['blocks'] }],
[provide, { target: '?.bemdecl.js' }],
[techs.deps],
[techs.files]
]);
Копирует BEMDECL-файл в текущую ноду по указанному имени из указанной ноды.
Может понадобиться для объединения BEMDECL-файлов из разных нод.
Тип: String
. По умолчанию: ?.bemdecl.js
(демаскируется в рамках текущей ноды).
Результирующий BEMDECL-файл.
Тип: String
. Обязательная опция.
Путь ноды с исходным BEMDECL-файлом.
Тип: String
. По умолчанию: ?.bemdecl.js
(демаскируется в рамках исходной ноды).
Исходный BEMDECL-файл, который будет скопирован.
var techs = require('enb-bem-techs');
/**
* Ноды в файловой системе до сборки:
*
* bundles/
* ├── bundle-1/
* └── bundle-1.bemdecl.js
* ├── bundle-2/
* └── bundle-1.bemdecl.js
* └── bundle-3/
*
* Что должно получиться после сборки:
*
* bundles/
* ├── bundle-1/
* └── bundle-1.bemdecl.js
* ├── bundle-2/
* └── bundle-2.bemdecl.js
* └── bundle-3/
* ├── bundle-1.bemdecl.js
* └── bundle-2.bemdecl.js
*/
config.node('bundle-3', function (nodeConfig) {
nodeConfig.addTechs([
// Копируем BEMDECL-файл из ноды `bundle-1` в `bundle-3`
[techs.provideBemdecl, {
node: 'bundles/bundle-1',
target: 'bundle-1.bemdecl.js'
}],
// Копируем BEMDECL-файл из ноды `bundle-2` в `bundle-3`
[techs.provideBemdecl, {
node: 'bundles/bundle-2',
target: 'bundle-2.bemdecl.js'
}]
]);
});
Копирует DEPS-файл в текущую ноду по указанному имени из указанной ноды.
Может понадобиться для объединения DEPS-таргетов из разных нод.
Тип: String
. По умолчанию: ?.deps.js
(демаскируется в рамках текущей ноды).
Результирующий DEPS-файл.
Тип: String
. Обязательная опция.
Путь ноды с исходным DEPS-файлом.
Тип: String
. По умолчанию: ?.deps.js
(демаскируется в рамках исходной ноды).
Исходный DEPS-файл, который будет скопирован из указанной ноды.
var techs = require('enb-bem-techs');
/**
* Ноды в файловой системе до сборки:
*
* bundles/
* ├── bundle-1/
* └── bundle-1.deps.js
* ├── bundle-2/
* └── bundle-1.deps.js
* └── bundle-3/
*
* Что должно получиться после сборки:
*
* bundles/
* ├── bundle-1/
* └── bundle-1.deps.js
* ├── bundle-2/
* └── bundle-2.deps.js
* └── bundle-3/
* ├── bundle-1.deps.js
* └── bundle-2.deps.js
*/
config.node('bundle-3', function (nodeConfig) {
nodeConfig.addTechs([
// Копируем DEPS-файл из ноды `bundle-1` в `bundle-3`
[techs.provideDeps, {
node: 'bundles/bundle-1',
target: 'bundle-1.deps.js'
}],
// Копируем DEPS-файл из ноды `bundle-2` в `bundle-3`
[techs.provideDeps, {
node: 'bundles/bundle-2',
target: 'bundle-2.deps.js'
}]
]);
});
Объединяет BEMDECL-файлы в результирующий.
Может понадобиться для формирования merged
-бандла.
Тип: String
. По умолчанию: ?.bemdecl.js
.
Результирующий BEMDECL-файл.
Тип: String[]
. Обязательная опция.
Исходные BEMDECL-файлы.
var techs = require('enb-bem-techs');
/**
* Ноды в файловой системе до сборки:
*
* merged-bundle/
* ├── bundle-1.bemdecl.js
* └── bundle-2.bemdecl.js
*
* Что должно получиться после сборки:
*
* merged-bundle/
* ├── bundle-1.bemdecl.js
* ├── bundle-2.bemdecl.js
* └── merged-bundle.bemdecl.js
*/
nodeConfig.addTech([techs.mergeBemdecl, {
sources: ['bundle-1.bemdecl.js', 'bundle-2.bemdecl.js'],
target: 'merged-bundle.bemdecl.js'
}]);
Объединяет DEPS-файлы и BEMDECL-файлы в результирующий DEPS-файл.
Может понадобиться для формирования merged
-бандла.
Тип: String
. По умолчанию: ?.deps.js
.
Результирующий DEPS-файл.
Тип: String[]
. Обязательная опция.
Исходные DEPS-файлы. Обязательная опция.
var techs = require('enb-bem-techs');
/**
* Ноды в файловой системе до сборки:
*
* merged-bundle/
* ├── bundle-1.deps.js
* └── bundle-2.deps.js
*
* Что должно получиться после сборки:
*
* merged-bundle/
* ├── bundle-1.deps.js
* ├── bundle-2.deps.js
* └── merged-bundle.deps.js
*/
nodeConfig.addTech([techs.mergeDeps, {
sources: ['bundle-1.deps.js', 'bundle-2.deps.js'],
target: 'merged-bundle.deps.js'
}]);
Формирует DEPS-файл, вычитая один DEPS-файл из другого.
Тип: String
. По умолчанию: ?.deps.js
.
Результирующий DEPS-файл.
Тип: String
. Обязательная опция.
DEPS-файл, из которого вычитают.
Тип: String
. Обязательная опция.
DEPS-файл, который вычитают.
var techs = require('enb-bem-techs');
nodeConfig.addTech([techs.subtractDeps, {
from: 'bundle-1.deps.js',
what: 'bundle-2.deps.js',
target: 'bundle.deps.js'
} ]);
© 2014 YANDEX LLC. Код лицензирован Mozilla Public License 2.0.