Получение SEO данных элементов и разделов инфоблока, через API 1С-Битрикс

Просмотров: 488

Для того чтобы извлечь данные из вкладки SEO административной панели Битрикс, необходимо использовать специализированные классы для работы с наследуемыми свойствами элементов и разделов инфоблока.

Получение SEO данных елементов и разделов инфоблока, через API 1С-Битрикс

Для работы с элементами информационных блоков вам пригодится класс \Bitrix\Iblock\InheritedProperty\ElementValues. Этот инструмент обеспечивает получение наследуемых свойств элемента, таких как заголовок страницы, мета-теги title и description.

$iBlockId = 1; // ID инфоблока
$elementId = 2; // ID элемента
// Создаем экземпляр класса для работы с наследуемыми свойствами элементов инфоблока
$seoFromElement = new \Bitrix\Iblock\InheritedProperty\ElementValues($iBlockId, $elementId);

// Получаем значения наследуемых свойств элемента
$pageProperties = $ipropElementValues->getValues();

// Устанавливаем заголовок страницы
$APPLICATION->SetTitle($seoFromElement['ELEMENT_PAGE_TITLE']);
// Устанавливаем мета-тег title
$APPLICATION->SetPageProperty('title', $seoFromElement['ELEMENT_META_TITLE']);
// Устанавливаем мета-тег description
$APPLICATION->SetPageProperty('description', $seoFromElement['ELEMENT_META_DESCRIPTION']);

Для работы со свойствами разделов инфоблока используйте класс \Bitrix\Iblock\InheritedProperty\SectionValues. Он также предоставляет возможность получить аналогичные свойства для разделов.

$iBlockId = 1; // ID инфоблока
$sectionId = 2; // ID раздела
// Создаем экземпляр класса для работы с наследуемыми свойствами разделов инфоблока
$seoFromSection = new \Bitrix\Iblock\InheritedProperty\SectionValues($iBlockId, $sectionId);

// Получаем значения наследуемых свойств раздела
$IPROPERTY  = $ipropValues->getValues();

// Устанавливаем заголовок страницы
$APPLICATION->SetTitle($seoFromSection['ELEMENT_PAGE_TITLE']);
// Устанавливаем мета-тег title
$APPLICATION->SetPageProperty('title', $seoFromSection['ELEMENT_META_TITLE']);
// Устанавливаем мета-тег description
$APPLICATION->SetPageProperty('description', $seoFromSection['ELEMENT_META_DESCRIPTION']);

Пример использоватия InheritedProperty\SectionValues

Например, в каталоге товаров выводится описание раздела из стандратного поля. Но если описание раздела не заполнено выведем описание сгенерированное штатным функционалом 1С-Битрикс

// В section.php шаблона каталога:
$arResult['SECTION_ID'] = CIBlockFindTools::GetSectionID(
    $arResult['VARIABLES']['SECTION_ID'],
    $arResult['VARIABLES']['SECTION_CODE'],
    array('IBLOCK_ID' => $arParams['IBLOCK_ID'])
);
$ipropValues = new \Bitrix\Iblock\InheritedProperty\SectionValues(
        $arParams['IBLOCK_ID'],
        $arResult['SECTION_ID']
);
$seoProps = $ipropValues->getValues(); // SEO данные раздела
$sectionResult = CIBlockSection::GetList(
    false,
    array(
        "IBLOCK_ID" => $arParams["IBLOCK_ID"],
        "ID" => $arResult["SECTION_ID"]
    ),
    false,
    array(
        'DESCRIPTION'
    )
);
while ($sectionProp = $sectionResult->Fetch()) {
    if (empty($sectionProp['DESCRIPTION'])) {
      // Если нет описания, выводим из метатега DESCRIPTION
        echo $seoProps['SECTION_META_DESCRIPTION'];
    } else {
      // Если есть - то показываем описание
        echo $sectionProp['DESCRIPTION'];
    }
}

Таким же образом можно "заполнить" описание товара, если у него не заполнен детальный текст.

Перетащите файлы
Ничего не найдено
Нажимая кнопку "Отправить" вы соглашаетесь
с политикой конфиденциальности и обработки персональных данных.