UK
Форум

Методологія

Інструментарій

Платформа

Перевод этой статьи на ваш язык отсутствует, вы можете помочь нам перевести.

Контекст

Методы экземпляра исполняются в контексте JS-объекта экземпляра блока и элемента. Ключевое слово this в методах экземпляра блока ссылается на JS-объект экземпляра.

Статические методы исполняются в контексте JS-объекта, соответствующего классу блока или элемента. Ключевое слово this в статических методах блока ссылается на класс.

Примечание При разработке с использованием i-bem.js внутренним методам блока и элемента, не предназначенным для использования извне, принято давать имена, начинающиеся с символа подчеркивания. Например, _onClick.

Свойства и методы экземпляра блока и элемента

С DOM-представлением

Без DOM-представления

Вспомогательные свойства

Экземпляр предоставляет набор вспомогательных свойств:

Пример

Вызов статического метода staticMethod() в методе _onEvent() экземпляра блока my-block.

bemDom.declBlock('my-block', {
    _onEvent : function() {
        this.__self.staticMethod(); // вызов статического метода
        this.doMore();
    }
}, {
    staticMethod : function() { /* ... */ } // определение статического метода
});

Пример

Вызов базовой реализации метода _onClick базового класса button.

modules.define('my-button', ['i-bem-dom', 'button'], function(provide, bemDom, Button) {

provide(bemDom.declBlock(this.name, Button, {
    _onClick : function() {
        this.__base(); // вызываем базовый _onClick
        this.doMore();
    }
}));

});

Вспомогательные свойства предоставляются модулем inherit, реализующим механизм наследования в bem-core.

Вспомогательные методы

Пример

Подписываемся на событие pointerclick на документе в следующем витке событийного цикла, чтобы попап не закрывался (по клику во вне) до того, как обработается клик на нём.

modules.define('popup', ['i-bem-dom'], function(provide, bemDom) {

provide(bemDom.decl(this.name, {
    onSetMod : {
        'visible' : {
            'true' : function() {
                this._nextTick(function() {
                    this._domEvents(bemDom.doc).on('pointerclick', this._onDocPointerClick);
                });
            }
        }
    },

    _onDocPointerClick : function() {
        // ...
        this.delMod('visible');
    }
}));

});

Статические свойства блока и элемента

Вспомогательные свойства

В декларации статических методов доступны вспомогательные свойства:

modules.define('my-button', ['i-bem-dom', 'button'], function(provide, bemDom, Button) {

provide(bemDom.declBlock(this.name, Button,
    { /* ... */ },
    {
        staticMethod: function() {
            this.__base();
            this.doMore();
        }
    }
));

});

Статические свойства модуля i-bem-dom

doc-rating:rate
Повідомити про помилку на Гітхабі або поправити за допомогою prose.io.