Как стать автором
Обновить

jQuery-плагин для организации компонентов на странице

Время на прочтение2 мин
Количество просмотров20K
JBlocks — небольшой jQuery-плагин (~100 строк) для организации компонентов на странице.

Строится на трех основных принципах:

  • опиши поведение компонента в декларации;
  • разметь компонент в html с помощью специальных атрибутов;
  • общайся со экземплярами компонента через АПИ.

Если вам интересна тема декларативного javascript — прошу под кат.

Пусть у нас есть простой контрол: счетчик. Шаг счетчика — параметр, который можно менять для разных экземпляров.
image
Демо

Объявим новый компонент counter:

$.jblocks({
    // имя компонента
    name: 'counter',

    // декларация событий
    events: {
        // встроенные события: b-inited, b-destroyed
        'b-inited': 'oninit',

        // дом-события
        'click .js-inc': 'onClickPlus',
        'click .js-dec': 'onClickMinus'
    },

    // методы компонента
    methods: {
        oninit: function() {
            this.$info = this.$node.find('.js-info');
            this.count = 0;
        },

        /**
         * Обработчик клика на плюс
         */
        onClickPlus: function() {
            this.inc();
            this.update();
        },

        /**
         * Обработчик клика на минус
         */
        onClickMinus: function() {
            this.dec();
            this.update();
        },

        /**
         * Увеличить счетчик
         */
        inc: function() {
            this.count += this.params.step;
        },

        /**
         * Уменьшить счетчик
         */
        dec: function() {
            this.count -= this.params.step;
        },

        /**
         * Нарисовать новое значение
         */
        update: function() {
            this.$info.text(this.count);
        }
    }
});

Разметим в html компонент с помощью специальных атрибутов:

<div class="foo" data-b="сounter" data-p='{ "step": 2 }'>
    ...
</div>

  • data-b — айдишник блока (имя)
  • data-p — параметры блока


Компоненты можно инициализировать с помощью $.fn.jblocks('init') и уничтожать с помощью $.fn.jblocks('destroy'):

// Инициализируем все блоки в документе
$(document).jblocks('init');

// Уничтожаем все блоки в документе
$(document).jblocks('destroy');

// Или внутри конретной части DOM-дерева
$('#app').jblocks('init');

С помощью функции $.fn.jblocks('get') можно получать ссылки на экземпляры. Если компонент еще не был инициализирован, то сперва это будет сделано.

$('.foo').jblocks('get').each(function() {
    // this - экземпляр блока, inc — его метод
    this.inc();
});


UPD:

Спасибо всем за конструктивную критику (и даже один пул реквест). Обновил репозиторий и описание статьи в соответствии с новым АПИ.

UPD:

Как правильно заметил GIum, это не «нано» пока зависит от jQuery. Теперь это реально несколько сотен строк vanillajs :)
Теги:
Хабы:
Всего голосов 29: ↑21 и ↓8+13
Комментарии74

Публикации

Истории

Работа

Ближайшие события

27 августа – 7 октября
Премия digital-кейсов «Проксима»
МоскваОнлайн
14 сентября
Конференция Practical ML Conf
МоскваОнлайн
19 сентября
CDI Conf 2024
Москва
20 – 22 сентября
BCI Hack Moscow
Москва
24 сентября
Конференция Fin.Bot 2024
МоскваОнлайн
25 сентября
Конференция Yandex Scale 2024
МоскваОнлайн
28 – 29 сентября
Конференция E-CODE
МоскваОнлайн
28 сентября – 5 октября
О! Хакатон
Онлайн
30 сентября – 1 октября
Конференция фронтенд-разработчиков FrontendConf 2024
МоскваОнлайн
3 – 18 октября
Kokoc Hackathon 2024
Онлайн