Получить и вывести все цены товара в 1С-Битрикс

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

Задача: получить и вывести все цены товара по его ID в каталоге 1С-Битрикс (например, в детальной карточке catalog.element), независимо от того, разрешен ли просмотр цены конкретной группе пользователей.

Получить и вывести все цены товара в 1С-Битрикс

Для получения всех цен товара в Битрикс вы можете использовать метод GetCatalogProductPriceList класса CCatalogProduct или метод GetList класса CPrice.

Использования метода GetCatalogProductPriceList

Наиболее правильным способом получения этих данных является использование файла result_modifier.php и дозаполнение массива $arResult.

$allProductPrices = \Bitrix\Catalog\PriceTable::getList([
    "select" => ["*"],
    "filter" => [
        "=PRODUCT_ID" => $arResult['ID'],
    ],
])->fetchAll();

foreach ($allProductPrices as $allProductPrice) {
    $arResult['ALL_PRICES'][] = $allProductPrice;
}

В этом примере мы передаем ID товара в метод GetCatalogProductPriceList и получаем список всех цен для этого товара. Затем мы перебираем результаты и добавляем их в массив $arResult['ALL_PRICES'].

Массив $arResult['ALL_PRICES'] будет содержать все данные о ценах, которые можно использовать в шаблоне.

Использование метода GetList класса CPrice

use Bitrix\Catalog\PriceTable;

$prices = \CPrice::GetList([], [
    'PRODUCT_ID' => $arResult['ID']
]);

while ($price = $prices->Fetch()) {
    $arResult['ALL_PRICES'][] = $price;
}

В этом примере используется класс CPrice и метод GetList, в котором передается фильтр по PRODUCT_ID для получения цен, связанных с определенным товаром. Затем, аналогично первому примеру, мы добавляем полученные цены в массив $arResult['ALL_PRICES'].

Сравнение двух типов цен для иммитации системы скидок

Исходя из этих примеров, можно реализовать имитацию системы скидок, фактически не создавая скидок. Пример:

// result_modifier.php =======================
$allProductPrices = \Bitrix\Catalog\PriceTable::getList([
    "select" => [
    	"PRICE" // Нужна только цена
    ],
    "filter" => [
        "=PRODUCT_ID" => $arResult['ID'],
    ],
    "order" => [
            "PRICE" => "DESC" // Сортируем по уменьшению цены
    ]
])->fetchAll();

foreach ($allProductPrices as $allProductPrice) {
    $arResult['ALL_PRICES'][] = $allProductPrice;
}

// template.php ===============================
// Старая зачеркнутая цена
echo $arResult['ALL_PRICES']['0']['PRICE'];

// Цена покупки
echo $arResult['ALL_PRICES']['1']['PRICE'];

// Расчет процента (для вывода в лейбле, можно округлить с float)
echo $arResult['ALL_PRICES']['1']['PRICE'] * 100 / $arResult['ALL_PRICES']['0']['PRICE'];

Метод GetCatalogProductPriceList класса CCatalogProduct более оптимизирован и эффективен с точки зрения производительности, особенно при работе с большим количеством товаров. Этот метод осуществляет непосредственный запрос к базе данных, что позволяет получить список цен товара более эффективно.

В свою очередь, метод GetList класса CPrice работает с классическим API Битрикс и выполняет запросы на основе старых структур данных. В некоторых случаях, особенно при работе с большим объемом данных, это может вызывать некоторые затраты на производительность.

Михаил Базаров 27.05.2023
Таким образом, для получения всех цен товара рекомендуется использовать метод GetCatalogProductPriceList, поскольку он предлагает более эффективное решение с точки зрения производительности.