我发现处理将复选框分成多列的最好方法是使用array_chunk()函数将数组拆分成相等的子数组,然后使用双foreach循环来呈现列。
http://php.net/manual/en/function.array-chunk.php
echo '<div class="container">';
foreach(array_chunk($genreLists,5) as $row_value)
{
echo '<div class="row">';
foreach($row_value as $cell_key => $cell_value)
{
echo '<div class="cell">';
//echo your checkbox html here
echo '</div>'; // close cell
}
echo '</div>'; // close row
}
echo '</div>'; // close container
同样的概念可以与智者进行{foreach}的循环只要你把它分配给模板引擎之前执行array_chunk。实际上,在智者{$ VAR | array_chunk:5}应该工作作为改性剂
如果你想有复选框垂直表示,使用该功能来代替:
/* ----------[ func ARRAY CHUNK VERTICAL ]----------
A sister to array_chunk, but instead of horizontal, split
the data vertical
*/
function array_chunk_vertical($array = null,$cols = 3, $pad = array(null))
{
if (is_array($array) == true and !empty($array))
{
// total items in the array
$count = count($array);
// if count is empty
if(empty($count))
{
return false;
}
// if cols is some how still empty
if(empty($cols))
{
$cols = 3;
}
// count the number of vertical rows
$rows = ceil($count/$cols);
// group the array into colums
$array = array_chunk($array,$rows);
// if the array is less that the number of cols required
// pad it to ensure length remains constant
if (count($array) < $cols)
{
$array = array_pad($array,$cols,$pad);
}
// pad the array with a null character as required
foreach($array as $key => $value)
{
$array[$key] = array_pad($value,$rows,null);
}
// now inverse the rows with the cols
foreach($array as $key => $value)
{
foreach($value as $sub_key => $sub_value)
{
$output[$sub_key][$key] = $sub_value;
}
}
// spit it out
return $output;
}
// oops
return $array;
}
你能更具体并提供生成代码? – Rodaine 2012-01-04 22:19:47
我添加了代码,它在smarty中,但它的形式与php相同。对于每个循环 – cppit 2012-01-04 22:27:31
不太熟悉smarty,但添加一个计数器,在复选框中将每个10复选框包装在一个带有“float:left”和“display:block”的复选框中应该可以实现 - 我想 – ptriek 2012-01-04 22:34:03