bem/bem-tools
-
getCreateResult: function(...) {
// ваш код
} -
##### Простой способ
-
В простом способе к экспортируемым функциям добавляется переменная `baseTechPath`, в которой
содержится абсолютный путь до расширяемого модуля технологии. -
```js
var BEM = require('bem'); -
exports.baseTechPath = BEM.require.resolve('./techs/css');
``` -
Так же вы можете организовать контекстное наследование, использую переменную `baseTechName`.
В этом случае базовый класс будет выбран в зависимости от уровня переопределения, на котором
будет использован модуль технологии. -
```js
exports.baseTechName = 'css';
``` -
В этом примере новая технология будет расширять технологию `css`, заданную на уровне переопределения
в файле `.bem/level.js`. -
##### Для продвинутых
-
Если вам нужен полный контроль, вы можете создать модуль, экспортирующий готовый класс технологии `Tech`.
-
```js
var INHERIT = require('inherit'),
BaseTech = require('bem/lib/tech').Tech; -
exports.Tech = INHERIT(BaseTech, {
-
create: function(prefix, vars, force) {
// do some creation work
}, -
build: function(prefixes, outputDir, outputName) {
// organize own build process
} -
Если в качестве базовой технологии вы хотите использовать одну из существующих технологий,
написанных в простом стиле, воспользуйтесь функцией `getTechClass()` для получения класса
этой технологии. Мы рекомендуем всегда использовать `getTechClass()`, чтобы не зависеть
от реализации базовой технологии. -
```js
var INHERIT = require('inherit'),
BEM = require('bem'),
BaseTech = BEM.getTechClass(require.resolve('path/to/tech/module')); -
// ваш код
-
##### Примеры модулей технологий
-
* [bem-tools/lib/techs/](https://github.com/bem/bem-tools/tree/nodejs/lib/techs)
* [bem-bl/blocks-common/i-bem/bem/techs/](https://github.com/bem/bem-bl/tree/master/blocks-common/i-bem/bem/techs) -
### Использование через API
No more segments to load.
Loading more segments…
© 2009-2024 WebTranslateIt Software S.L. All rights reserved.
Terms of Service
·
Privacy Policy
·
Security Policy