假设我有8个php对象,我需要对它们进行迭代,并根据它们的位置将各种信息以不同的方式输出到html中。我已经开发了css和html的结构,你可以在这里看到它:http://jsfiddle.net/v3qcc/9/我只需要在动态放置它们的逻辑方面得到帮助。
我需要把每两个对象放在这个包装器中:
<div class="col">
<div class="third">
<div class="col-content">
**...Object One Here**
</div>
</div>
<div class="fourth">
<div class="col-content">
**...Object Two Here**
</div>
</div>
</div>
<div class="col">
<div class="third">
<div class="col-content">
**...Object Three Here**
</div>
</div>
<div class="fourth">
<div class="col-content">
**...Object Four Here**
</div>
</div>
</div>
// heres a class
class thing {
public $ybob = 23;
}
// create an array of 8 of them
$i = 0;
$a= array();
while(8> $i){
$a[$i] = new thing;
$i++;
}
//var_dump($a);
// loop thru the array of objects
$rows = 1;
foreach($a as $ob){
// use modulus operator to work out if a row is odd or even
echo ( ($rows % 2) === 1 ) ? '<br />NEW ROW' : '' ;
echo $ob->ybob . ' - ' ; // output the objects data in any case
$rows++;
}
在向上4行的三元运算符中,如果您想使用更多的标记行,您可以添加额外的行标记,或者恢复if/else。
提供:
NEW ROW 23 - 23 -
NEW ROW 23 - 23 -
NEW ROW 23 - 23 -
NEW ROW 23 - 23 -
试试这个:
<?php
echo '<div class="col">';
for ($i=0; $i<$max_elements; $i++)
{
$class = ($i&1) ? "third" : "fourth";
echo '<div class="'.$class.'">
<div class="col-content">
**...Object num : '.$i.' Here**
</div>
</div>';
}
echo '</div>';
Personnaly,我将在循环中测试每次递增的指示符,无论它是偶数还是奇数,并根据此显示模板需要。