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

Использование $APPLICATION->RestartBuffer() в связке с AJAX-запросами

Просмотров: 3241 Часто возникает необходимость управлять выводом данных на страницу, особенно когда речь идет о взаимодействии с AJAX-запросами. Один из полезных методов для этого — $APPLICATION->RestartBuffer().

Что такое $APPLICATION->RestartBuffer()?

Метод $APPLICATION->RestartBuffer() используется для сброса буфера вывода в 1С-Битрикс. Это значит, что все данные, которые были выведены до вызова этого метода, будут удалены, включая шаблон страницы. Таким образом, вы сможете начать выводить новые данные.

Пример использования: автоматическое обновление элементов на странице

Предположим, что задача состоит в том, чтобы каждые 10 секунд отправлять AJAX-запрос к внутренней странице сайта и обновлять список новостей на текущей странице. Для этого нужно выполнить следующие шаги:

  • Обернуть шаблон списка новостей (например, компонент news.list) в проверку на наличие AJAX-запроса.
  • В случае AJAX-запроса вызвать $APPLICATION->RestartBuffer(), чтобы исключить все, кроме новостей, из ответа.
  • В конце выполнения скрипта вызвать die(), чтобы прервать дальнейшее выполнение и отправить только обновленный блок.
// файл template.php вашего списка новостей
use Bitrix\Main\Application;
$request = Application::getInstance()->getContext()->getRequest();

if ($request->isAjaxRequest()) {
    // Если это AJAX запрос Очистка буфера вывода, чтобы в ответе были только новости
    // По сути "отрезаем" весь вывод до сюда
    $APPLICATION->RestartBuffer();
}
foreach ($arResult["ITEMS"] as $arItem) {
    // шаблон компонента новостей
    // ...
}
if ($request->isAjaxRequest()) {
    // Если это AJAX запрос прекращаем "создавать" страницу
    die();
}

На страницу, где планируется вывод новостей (запросом с другой страницы), добавляем JavaScript для автоматического обновления блока и блок, в который будет вставляться ответ:

<div id="news-container"></div>
<script>
setInterval(function () {
    fetch('/news/index.php') // Путь к странице источнику
        .then(response => response.text())
        .then(data => {
            document.getElementById('news-container').innerHTML = data;
        });
}, 10000); // обновлять каждые 10 секунд
</script>
Да, пример немного "надуманный", Но для понимания работы метода, более чем уместен. Для решения описанной задачи можно было вывести компонент на страницу и обновлять его AJAX запросом без $APPLICATION->RestartBuffer().

Обработка формы обратной связи с JSON-ответом

Более наглядный пример работы. Предположим, на странице есть форма которая отправляет запрос к самой себе (обработчик формы находится по этому же адресу). Нужно "обрезать" шаблон сайта при получении результата:

use Bitrix\Main\Application;

$request = Application::getInstance()->getContext()->getRequest();
if ($request->isAjaxRequest()) {
    $APPLICATION->RestartBuffer();

    // Обработка данных формы
    $name = $request->getPost('name');
    $email = $request->getPost('email');

    // Здесь можно добавить логику для сохранения данных или отправки email

    // Формируем ответ
    $response = [
        'status' => 'success',
        'message' => 'Спасибо за ваше сообщение, ' . htmlspecialchars($name) . '!'
    ];

    // Отправляем JSON-ответ
    header('Content-Type: application/json');
    echo json_encode($response);
    die();
}

Может пригодиться заметка:
Работа с HTTP-запросами в Bitrix

В этом примере, если запрос является AJAX-запросом, мы очищаем буфер вывода, обрабатываем данные формы и отправляем JSON-ответ с сообщением об успешной отправке.

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

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

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

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

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

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

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

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

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

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

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

Подробнее
Поддержка и доработки проектов
от 3 000 руб. от 1 часа

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

Подробнее

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

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

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