Михаил Базаров Разработка на 1С-Битрикс Михаил Базаров

Fancybox в стандартном шаблоне детальной карточки товара, 1С-Битрикс, вместо всплывающего окна и лупы.

Просмотров: 5050 Задача: заменить работу с изображениями в стандартном или кастомном шаблоне детальной карточки (catalog.element) 1С-Битрикс, с "всплывающего окна" и "лупы" на работу с fancybox. При этом необходимо обеспечить работу с торговыми предложениями, заменяя коллекцию картинок.
Fancybox в стандартном шаблоне детальной карточки товара

Подключаем fancybox к сайту

Скачиваем библиотеку fancybox и распаковываем ее в директорию шаблона сайта. Так как fancybox может пригодиться не только на странице детальной карточки, но и в других местах сайта, мы подключим его глобально в файле header.php.

Скачать fancybox
use Bitrix\Main\Page\Asset;
CJSCore::Init(array("jquery3"));
Asset::getInstance()->addCss(SITE_TEMPLATE_PATH . '/fancybox/jquery.fancybox.css');
Asset::getInstance()->addJs(SITE_TEMPLATE_PATH . '/fancybox/jquery.fancybox.js');

Обратите внимание, что для работы fancybox нужна подключенная библиотека jQuery. Я подключил третью версию из ядра 1С-Битрикс, используя функцию CJSCore::Init(), передав в качестве параметра массив со значением "jquery3". Эта функция инициализирует и подключает необходимые ядру библиотеки.

Подменяем битриксовые библиотеки, работы с картинками, на fancybox

Для начала заходим в настройки компонента каталога и в настройках детального отображения карточки отключаем режим показа детальной картинки, чтобы в параметре не было ничего указано..

в настройках детального отображения карточки отключаем

Открываем на редактирование файл скрипта детальной карточки товара:
/ВАШ_ШАБЛОН_САЙТА/components/bitrix/catalog.element/ШАБЛОН_ДЕТАЛЬНОЙ/script.js
Находим в нем участок кода, который формирует вывод верстки картинок (примерно на 2710-ой строке).

this.node.imageContainer.appendChild(
    BX.create('DIV', {
        attrs: {
            'data-entity': 'image',
            'data-id': images[i].ID
        },
        props: {
            className: 'product-item-detail-slider-image' + (i == 0 ? ' active' : '')
        },
        children: [img]
    })
);

Заменяем этот участок на код, который сформирует верстку картинок товара с необходимыми атрибутами fancybox.

this.node.imageContainer.appendChild(
    BX.create('A', {
        attrs: {
            'data-entity': 'image',
            'data-fancybox':'images',
            'href': images[i].SRC,
            'data-id': images[i].ID
        },
        props: {
            className: 'product-item-detail-slider-image' + (i == 0 ? ' active' : '')
        },
        children: [img]
    })
);

На этом все, вот так просто можно заменить битриксовые библиотеки работы с картинками на нормальный и управляемый fancybox.


Услуги Стоимость разработки на 1С-Битрикс

Стоимость разработки сайта зависит от объёма и сложности проекта. Ниже приведены ориентировочные цены, как правило не выходят за обозначенные рамки. Срок разработки зависит от сложности проекта: как правило называю сроки с запасом.
Финальная стоимость и сроки разработки обговариваются на этапе обсуждения. Скачайте опросник на разработку, заполните как можно подробнее и вышлите удобным способом. После ознакомления смогу задать уточняющие вопросы и оценить проект.
Поддержка и доработки проектов
от 3 000 руб. от 1 часа

Выполнение доработок любой сложности. Поддержка, модернизация и расширение функционала существующих проектов. Решение задач: от мелких правок вёрстки до разработки новых модулей.

Подробнее
Сайт на готовом решении 1С-Битрикс
от 70 000 руб. от 5-ти дней

Вариант для тех, кто не хочет тратить много средств на индивидуальный проект, и не имеет серьезных требований к сайту. Магазин, быстро запускается на базе одного из 200-та готовых решений.

Подробнее
Индивидуальная разработка магазина
от 300 000 руб. от 5-ти недель

Разработка магазина на 1С-Битрикс с нуля. Дизайн, сборка и оптимизация производительности под конкретный проект и требования. Реализация любого функционала без ограничений готовых решений.

Подробнее
Мобильное приложение
от 300 000 руб. от 4-х недель

Разработка кроссплатформенного мобильного приложения, которое не уступает нативным решениям как в производительности, так и пользовательском опыте. Публикуется в AppStore, GooglePlay и RuStore

Подробнее
Инфоресурс
от 170 000 руб. от 3-х недель

Информационный ресурс любой сложности. Сайт для СМИ, городской портал или многопользовательская доска объявлений. Внутренние форумы, блоги- по необходимости.

Подробнее
Сайт компании
от 150 000 руб. от 2-х недель

Корпоративный сайт с информационными разделами, каталогом товаров или услуг. Включает формы обратной связи карточек каталога, любое количество статичных и динамичных разделов.

Подробнее

Включено в стоимость разработки:

  • Лицензия на 1С-Битрикс необходимой редакции, дополнительные модули, для реализации функционала и видео-инструкции по работе с готовым проектом
  • Оптимизация программной части проекта и конфигурации сервера под максимальную скорость работы. Базовая СЕО оптимизация и добавление сайта в поисковые системы.

Блог-note Заметки по 1С-Битрикс