bem/bem-tools
-
Если вам нужен полный контроль, вы можете создать модуль, экспортирующий готовый класс технологии `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
-
В версии 0.2.0 появилась возможность использовать команды `bem-tools` через API.
-
Модуль `bem` экспортирует объект основной команды, у которого есть свойство `api`.
Использовать его можно так: -
```js
var Q = require('q'),
BEM = require('bem').api, -
techs = ['css', 'js'],
blocks = ['b-block1', 'b-block2']; -
Q.when(BEM.create.block({ forceTech: techs }, { names: blocks }), function() {
console.log('Create blocks: %s', blocks.join(', '));
});
``` -
Как видно из примера, можно обращаться ко всем командам `bem-tools`, в том числе вложенным.
-
Команды принимают два аргумента:
-
* **Object** `opts` опции команды
* **Object** `args` аргументы команды -
Возвращают объект типа `Q.promise`.
No more segments to load.
Loading more segments…
© 2009-2024 WebTranslateIt Software S.L. All rights reserved.
Terms of Service
·
Privacy Policy
·
Security Policy