Новости Joomla

Вышли релизы Joomla 6.1 и Joomla 5.4.5: новые возможности и стабильность

Релиз Joomla 6.1.0

Проект Joomla! объявил о доступности Joomla 6.1 [Nyota] — новой минорной версии шестой серии, а также о выпуске релиза исправлений ошибок Joomla 5.4.5. Релиз 6.1 приносит ряд долгожданных функций, повышающих удобство управления контентом и защиту от спама.

0 Пользователей и 1 Гость просматривают эту тему.
  • 5 Ответов
  • 3268 Просмотров
*

nastjushka

  • Осваиваюсь на форуме
  • 49
  • 7 / 0
У меня есть сложный каталог типа:

Тип детали
- Марка авто
-- Модель авто

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

Мне в карточке товара нужно указать "Тип детали", т.е. родительскую категорию товара, как это сделать?

Подскажите пожалуйста.
*

fsv

  • Moderator
  • 2787
  • 413 / 2
В переопределенном шаблоне карточки товара:
Код: php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
    echo $parent->category_name;
}
Веб-разработка: заказ. Только новая разработка.
*

nastjushka

  • Осваиваюсь на форуме
  • 49
  • 7 / 0
В переопределенном шаблоне карточки товара:
Код: php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->category_name ){
    echo $parent->category_name;
}


Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
*

fsv

  • Moderator
  • 2787
  • 413 / 2
Спасибо, так он у меня начал выводить категорию "Марка авто", а как прописать, чтобы выводил  "Тип детали"?
попробуйте
Код: php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->virtuemart_category_id ){
$grandparent = $cat->getParentCategory((int)$parent->virtuemart_category_id);
if( $grandparent->category_name ){
echo $grandparent->category_name;
}
}
не проверял

Только вот есть некоторые сомнения... Включите отладку и посмотрите, сколько запросов генерирует эта борода. Возможно, будет лучше не использовать API VM, а написать 1 запрос в базу.
Веб-разработка: заказ. Только новая разработка.
*

nastjushka

  • Осваиваюсь на форуме
  • 49
  • 7 / 0
Работает, если есть три уровня вложенности, но если вдруг встречается два уровня или один - ничего не выводит...

Включила отладку, и 9347 SQL-запросов зафиксировано, но это по всей странице http://avtoimperial.by/catalogue, а как узнать отдельно по этому коду?
*

nastjushka

  • Осваиваюсь на форуме
  • 49
  • 7 / 0
Дописала так:
Код
<?php
$cat = VmModel::getModel('category');
$parent = $cat->getParentCategory((int)$this->product->virtuemart_category_id);
if( $parent->virtuemart_category_id ){
$grandparent = $cat->getParentCategory((int)$parent->virtuemart_category_id);
if( $grandparent->category_name ){
echo $grandparent->category_name;
}else{
echo $parent->category_name;}
} else {
echo $product->category_name;}
?>
 

Стал выводить все, как нужно)

Нужно ли заморачиваться с запросами к базе? ведь 9 тыс - это много? а если напрямую к базе делать запрос, то это как?

« Последнее редактирование: 20.07.2015, 12:52:07 от nastjushka »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться