bem-core library
This README is also available in English.
Информация о библиотеке в более информативном виде доступна на bem.info.
Что это?
Базовая библиотека блоков для разработки веб-интерфейсов. Содержит только необходимый минимум для разработки клиентского JS и HTML-шаблонов.
Использование
Наиболее простым способом начать проект с использованием bem-core
является
project-stub.
Вы также можете добавить библиотеку к себе в проект любым известным вам способом.
Состав
Уровни
common.blocks
— предназначен для любых устройств и браузеровdesktop.blocks
— следует использовать для всех десктопных браузеровtouch.blocks
— реализует некоторую специфику для тач-платформ
Блоки
i-bem
— базовый блок с хелперами для JS и HTMLstrings
— хелперы для JS-строкobjects
— хелперы для JS-объектовfunctions
— хелперы для JS-функцийevents
— JS-событияquerystring
— работа со строкой запросаtick
— глобальный таймерidle
— IDLE-событиеnext-tick
— полифил дляnextTick
/setTimeout(0, ...)
inherit
— ООП-хелперыjquery
— jQueryclearfix
— CSS-трюк clearfixidentify
— идентификация JS-объектовcookie
— хелперы для работы с браузерными кукамиvow
— реализация Promises/A+dom
— хелперы для работы с DOMloader
— загрузчик для JS-файловua
— определение возможностей браузераkeyboard
— хелперы для работы с клавиатуройpage
— скелет для html/head/body
Технологии
vanilla.js + browser.js
bemhtml
bemtree
API
Автосгенерированную документацию на JavaScript API блоков (JSDoc) можно посмотреть на bem.info. Например, для блока i-bem
она доступна по ссылке https://ru.bem.info/libs/bem-core/current/desktop/i-bem/jsdoc/.
История изменений
История изменений доступна на отдельной странице.
Миграция
Миграция описана на отдельной странице.
Разработка
Рабочая копия
Получаем исходники нужной версии (например,
v2
):$ git clone -b v2 git://github.com/bem/bem-core.git $ cd bem-core
Устанавливаем зависимости:
$ npm install
Для последующего запуска локально установленных npm-зависимостей нам потребуется
export PATH=./node_modules/.bin:$PATH
или любой альтернативный способ.Устанавливаем зависимые библиотеки:
$ npm run deps
Собираем примеры и тесты:
$ npm test
Запускаем разработческий сервер:
$ npm start
Внесение изменений
См. руководство по внесению изменений.
Модульное тестирование
Сборка дефолтного тестового бандла для functions__debounce
:
$ magic make desktop.specs/functions__debounce
После сборки тестового бандла вы увидите результаты выполнения тестов в консоли.
Их также можно посмотреть в браузере, открыв desktop.specs/functions__debounce/spec-js+browser-js+bemhtml/spec-js+browser-js+bemhtml.html
.
По аналогии можно запустить тесты для других БЭМ-сущностей, имеющих реализацию в технологии spec.js
.
Покрытие кода тестами
Чтобы собрать статистику покрытия кода тестами, необходимо добавить переменную окружения ISTANBUL_COVERAGE=yes
в сборке тестового бандла:
$ ISTANBUL_COVERAGE=yes magic make desktop.specs && istanbul report html
Сбор статистики покрытия тестами так же работает для запуска тестов конкретной БЭМ-сущности.
Пример для functions__debounce
$ ISTANBUL_COVERAGE=yes magic make desktop.specs/functions__debounce && istanbul report html
После завершения выполнения тестов, можно посмотреть отчет о покрытии кода тестами, открыв в браузере страницу
coverage/index.html
.
Полный отчет и статистику покрытия кода библиотеки тестами можно посмотреть на странице профиля bem-core в проекте Coveralls.
Для сборки и запуска тестов используется библиотека enb-bem-specs. См. подробную информацию про инфраструктуру тестирования.
Поддерживаемые браузеры
Мы поддерживаем браузеры на основе статистики, получаемой на сервисах Яндекса.
Браузеры с долей более 2% пользователей попадают в полную совместимость, с более 0.5% — в частичную, что означает, что данные будут доступны, но возможна деградация. В браузерах с долей менее 0.5% мы прекращаем тестирование.
Десктопы
Полная совместимость
Google Chrome 29+
Firefox 24+
Yandex 1.7+
Opera 12.16
MSIE 10.0
MSIE 9.0
MSIE 8.0
Opera 12.15
Частичная совместимость
Opera 17.0
Opera 16.0
Opera 12.14
Opera 12.2
Firefox 23
Тач-браузеры
Полная совместимость
iOS 6+
Android 2.3+
Opera Mobile 12+
Windows Phone 7+
Частичная совместимость
iOS 5
Android 2.2
Лицензия
© 2012 YANDEX LLC. Код лицензирован Mozilla Public License 2.0.