Организация результатов по категории Redux - PullRequest
0 голосов
/ 05 сентября 2011

Я пытаюсь расширить свой вопрос, заданный здесь: Создание многомерного массива из запроса

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

Вот код, который я использую для отображения элементов по категории:

$itemcategories = array();
while ($row = mysqli_fetch_array($result))
{
    $head = $row['category'];
    $itemcategories[$head][] = array(
      'id' => $row['id'],
      'title' => $row['title'],
      'itemdesc' => $row['itemdesc'],
      'price' => $row['price'],
      'special' => $row['special']
  );
}

<?php foreach ($itemcategories as $head => $items) { ?>
    <h3><?php echo $head; ?></h3>
    <table class="chart">
<?php foreach ($items as $item) { ?>
    <tr><td><?php echo $item['itemdesc']; ?></td></tr>
<?php } ?>
    </table>
<?php } ?>

1 Ответ

0 голосов
/ 05 сентября 2011
// to initial variable holder
$categories = $items = array();

// looping mysql result
while ($row = mysqli_fetch_array($result))
{
  // to get category name
  $head = $row['category'];

  // avoid excessive setting of $categories
  if (!isset($categories[$head]))
  {
    $categories[$head] = $row['descrption'];
  }

   // assign mysql result to $items
  $items[$head][] = $row;
}
// free mysql result
mysql_free_result($result);

// loop all $categories
foreach ($categories as $head=>$desc)
{
   // this is my example for printing HTML
   // you can use heredoc syntax
   // or stick to your existing format
   echo "<h3>{$head} - {$desc}</h3><table class="chart">";
   foreach ($items[$head] as $item)
   {
     // print item description
     echo "<tr><td>{$item['itemdesc']}</td></tr>";
   }
   echo "</table>";
}
...