使用foreach循环实现多列表

时间:2015-03-30 12:38:50

标签: php html foreach

我想实现一个使用foreach循环创建三列表的逻辑。示例代码如下所示。

$array = ['0','1','2','3','4','5','6'];
$table = '<table class="table"><tbody>';

foreach($array as $a=>$v){

    //if 0th or 3rd???????????wht should be here?
    $table .= '<tr>';

    $table .= '<td>$v</td>';

    //if 2nd or 5th??????????and here too???
    $table .= '</tr>';

}

$table = '</tbody></table>';            

有什么想法吗?

预期输出是一个简单的3X3表,其中包含数组中的值

4 个答案:

答案 0 :(得分:3)

使用这个你可以找这个

<?php
echo('<table><tr>');
$i = 0;
foreach( $array as $product )
{
   $i++;
   echo '<td>'.$product .'</td>';
   if($i % 3==0)
   {
      echo '</tr><tr>';
   }
}
echo'</tr></table>';
?>

结果:

<table>
   <tr>
      <td>data1</td>
      <td>data2</td>
      <td>data3</td>    
   </tr>    
   <tr>
     <td>data4</td>
     <td>data5</td>
     <td>data6</td>    
   </tr>
</table>

答案 1 :(得分:2)

这应该适合你:

(看到我在foreach循环之前和之后的开头和结尾添加了tr。我还将引号更改为双引号,并确保将文本附加到任何地方。)

<?php

    $array = ['0','1','2','3','4','5','6'];
    $table = "<table class='table'><tbody><tr>";
                                        //^^^^ See here the start of the first row
    foreach($array as $a => $v) {

        $table .= "<td>$v</td>";
                //^           ^ double quotes for the variables
        if(($a+1) % 3 == 0)
            $table .= "</tr><tr>";

    }
    $table .= "</tr></tbody></table>"; 
         //^   ^^^^^ end the row
         //| append the text and don't overwrite it at the end
    echo $table;

?>

输出:

<table class='table'>
<tbody>
    <tr>
        <td>0</td>
        <td>1</td>
        <td>2</td>
    </tr>
    <tr>
        <td>3</td>
        <td>4</td>
        <td>5</td>
    </tr>
    <tr>
        <td>6</td>
    </tr>
</tbody>
</table>

答案 2 :(得分:2)

这是一个使用array_chunk()的简单解决方案:

<?php

    $array = array('0','1','2','3','4','5','6');
    $d = array_chunk($array, 3);

    $table = "<table border='1' class='table'><tbody>";
    foreach($d as $v)
        $table .= "<tr><td>" . implode("</td><td>", $v) . "</td></tr>";

    $table .= "</tbody></table>";
    echo $table;

?>

答案 3 :(得分:0)

这是一个简单的解决方案,使用递增功能,可以使用动态生成的表格,例如Magento产品视图页面中的表格,以帮助在两个表格列中显示产品属性,前面是属性标签 - &gt;实际上我们有4个表格列和属性标签。这对于具有需要长页面显示的多个属性的产品非常有用。

<?php
$_helper = $this->helper('catalog/output');
$_product = $this->getProduct();
if($_additional = $this->getAdditionalData()): ?>

<h2><?php echo $this->__('Additional Information') ?></h2>
<table class="table table-bordered table-hover" id="product-attribute-specs-table">
    <col width="25%" />
    <col />
    <tbody>
    <?php $i = 1; ?>
    <tr>
    <?php foreach ($_additional as $_data): ?>
    <?php $_attribute = $_product->getResource()->getAttribute($_data['code']);
if (!is_null($_product->getData($_attribute->getAttributeCode())) && ((string)$_attribute->getFrontend()->getValue($_product) != '')) { ?>


            <th style="width: 20%;"><?php echo $this->htmlEscape($this->__($_data['label'])) ?></th>
            <td class="data" style="width:20%;"><?php echo $_helper->productAttribute($_product, $_data['value'], $_data['code']) ?></td>
            <?php $i++; if($i > 1 && ($i & 1) ) echo "</tr><tr>";?>

    <?php } ?>
    <?php endforeach; ?>
    </tr>
    </tbody>
</table>
<script type="text/javascript">decorateTable('product-attribute-specs-table')</script>