Перейти к содержанию
alexvdv

Почему foreach (opencart) внутри другого цикла не срабатывает

Рекомендуемые сообщения

Всем привет. Подскажите, что делаю не правильно.

Делаю вывод всех товаров на одной странице (прайс-лист)

 

Должно получиться так:

 

Категория товара:

 - все товары из категории

Категория товара 2:

- все товары из категории 2

Категория товара 3:

- все товары из категории 3

 

И так со всеми товарами магазина.

Но получается следующая картина, сначала выводятся все категории магазина, затем все товары магазина, цикл внутри цикла не работает правильно.

 

В контроллере:

 

$data['categories'] = array();

		$allcategories = $this->model_catalog_category->getCategories(0);

		foreach ($allcategories as $category) {

			$data['categories'][] = array(
					'name' => $category['name'] . ($this->config->get('config_product_count') ? ' (' . $this->model_catalog_product->getTotalProducts(0) . ')' : ''),
					'href' => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '_' . $category['category_id'] . $url)
			);
		}





		$category_allproducts = [];

		$allproducts = $this->model_catalog_product->getProducts($category['category_id']);
		//$allcategories = $this->model_catalog_category->getCategories($category['category_id']);

		if(!empty($allproducts)){
			foreach ($allproducts as $product)  { //3
				$category_allproducts[] = array (
						'name' => $product['name'],
						'href'        => $this->url->link('product/product', 'product_id=' . $product['product_id']),
				);
			}
		}





		// Level 1
		$data['categories'][] = array(
				'products'    => $category_allproducts,
				'name' => $product['name'],
				'href' => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '_' . $category['category_id'] . $url)
		);

 

Представление:

 

 <?php foreach ($categories as $category) { ?>
        <h2><?php echo $category['name']; ?></h2>

      <div class="row">
        <?php foreach ($category['products'] as $product) { ?>
        оформление карточки
        <?php } ?>
      </div>

        <?php } ?>

Что делаю не так?

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
$allproducts = $this->model_catalog_product->getProducts($category['category_id']);

Эта функция принимает массив с данными для фильтрации, чтобы фильтрануть по категории нужно передать в нее массив типа этого

$filter['filter_category_id'] = $category['category_id'];

 

Изменено пользователем baster789

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

+ у вас закрыт первый foreach и ссылка на $category по-идее проходить не должна

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

еще закрыт 3 цикл а в конце вы ссылаетесь на product['name'], и вы дважды забиваете категории в $data[''categories''] В начале и на level 1, в итоге у вас сначала в выводе появляются просто категории

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Я сейчас немного туго соображаю, но должно быть что-то вроде этого, как я понял

$allcategories = $this->model_catalog_category->getCategories(0);

foreach ($allcategories as $category) {


		$category_allproducts = [];
		$filter['filter_category_id'] = $category['category_id'];
		$allproducts = $this->model_catalog_product->getProducts($filter);

		if(!empty($allproducts)){
			foreach ($allproducts as $product)  { //3
				$category_allproducts[] = array (
						'name' => $product['name'],
						'href'        => $this->url->link('product/product', 'product_id=' . $product['product_id']),
				);
			}
		}



		

		// Level 1
		$data['categories'][] = array(
				'products'    => $category_allproducts,
				'name' => $category['name'] . ($this->config->get('config_product_count') ? ' (' . $this->model_catalog_product->getTotalProducts(0) . ')' : ''),
				'href' => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '_' . $category['category_id'] . $url)
		);
}

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Только что, baster789 сказал:

Я сейчас немного туго соображаю, но должно быть что-то вроде этого, как я понял


$allcategories = $this->model_catalog_category->getCategories(0);

foreach ($allcategories as $category) {


		$category_allproducts = [];
		$filter['filter_category_id'] = $category['category_id'];
		$allproducts = $this->model_catalog_product->getProducts($filter);

		if(!empty($allproducts)){
			foreach ($allproducts as $product)  { //3
				$category_allproducts[] = array (
						'name' => $product['name'],
						'href'        => $this->url->link('product/product', 'product_id=' . $product['product_id']),
				);
			}
		}



		

		// Level 1
		$data['categories'][] = array(
				'products'    => $category_allproducts,
				'name' => $category['name'] . ($this->config->get('config_product_count') ? ' (' . $this->model_catalog_product->getTotalProducts(0) . ')' : ''),
				'href' => $this->url->link('product/category', 'path=' . $this->request->get['path'] . '_' . $category['category_id'] . $url)
		);
}

 

 

Спасибо большое за помощь, так все работает отлично, буду теперь вникать

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Обращайтесь:)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Только что, baster789 сказал:

Обращайтесь:)

 

Еще добавил вывод товаров из подкатегории в родительскую, сделал так:

 

$filter_data = array(
					'filter_category_id'  => $category['category_id'],
					'filter_sub_category' => true
			);

			$allproducts = $this->model_catalog_product->getProducts($filter_data);

Все вроде работает как надо, так правильно?

 

Еще один вопрос, у меня почему-то когда идет вывод последней категории, при том что уже категории закончились создается еще одна категория, которая создаваться не должна из названия товара произвольно

http://prnt.sc/f3odfm

 

Почему так происходит и как это исправить?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Только что, alexvdv сказал:

 

Еще добавил вывод товаров из подкатегории в родительскую, сделал так:

 


$filter_data = array(
					'filter_category_id'  => $category['category_id'],
					'filter_sub_category' => true
			);

			$allproducts = $this->model_catalog_product->getProducts($filter_data);

Все вроде работает как надо, так правильно?

 

Еще один вопрос, у меня почему-то когда идет вывод последней категории, при том что уже категории закончились создается еще одна категория, которая создаваться не должна из названия товара произвольно

http://prnt.sc/f3odfm

 

Почему так происходит и как это исправить?

 

Не правильно) sub_category тоже id сообщается, только уже подкатегории

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

И кстати, чтобы правильно товары считались в кате тоже филтр передать нужно

'name' => $category['name'] . ($this->config->get('config_product_count') ? ' (' . $this->model_catalog_product->getTotalProducts($filter_data) . ')' : ''),

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Хотя я немного не так выразился про неправильно, все правильно в вашем случае) хотя я могу тупить:D

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Только что, baster789 сказал:

И кстати, чтобы правильно товары считались в кате тоже филтр передать нужно


'name' => $category['name'] . ($this->config->get('config_product_count') ? ' (' . $this->model_catalog_product->getTotalProducts($filter_data) . ')' : ''),

 

 

а как бороться с этим http://prnt.sc/f3odfm?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Только что, alexvdv сказал:

 

а как бороться с этим http://prnt.sc/f3odfm?

 

Все разобрался, был дублирующий массив в контроллере , удалил и все норм)))

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.