douman9420 2013-05-22 11:05
浏览 24
已采纳

使用foreach()创建表

I have following PHP code contain 2 foreachs

echo "<table class='table table-bordered'>";
foreach($resultOld as $key=>$value)
{
    foreach ($value as $key1 => $subjects) {
        $checked = $subjects;
        echo  "<tr><tr class=\"".$subjects."\">$key1
            <input type='checkbox' class=\"".$subjects."\"  value='checked' name=\"".$key1."JAN\" $checked/> </tr>               
           </tr>" ;
    }
}
echo "</table>";

$resultOld is a fetchAll(PDO::FETCH_ASSOC) output and it contains a two dimensional array. $subjects will return 661 words from the database which means the $resultOld array have 661 elements. And after every 12 cells I want to start a new line (tr). That means I need 55 rows in the table. How to achieve this using PHP?

  • 写回答

2条回答 默认 最新

  • dongzhi9457 2013-05-22 11:35
    关注

    If you want a new row after every 12 records, you need to use a counter and check the count -

    $counter = 1;
    echo "<table class='table table-bordered'>";
    echo "<tr>"; //start the first row
    foreach($resultOld as $key=>$value)
    {
        foreach ($value as $key1 => $subjects) {
    
            // if the 13th cell, end last row, and start new row
            if ($counter%12==1){
                          echo "</tr><tr>";}
            $checked = $subjects;
            echo  "<td class=\"".$subjects."\">$key1
                <input type='checkbox' class=\"".$subjects."\"  value='checked' name=\"".$key1."JAN\" $checked/> </td>" ;
    
            // increase counter
            $counter++;
        }
    }
    echo "</tr>"; // end last row
    echo "</table>";
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部