Vin*_*gen 4 php foreach group-by
我正在使用下面的代码来显示webisites表格数据库的图像和名称.
<fieldset>
<h1>A</h1>
<ul>
<?php foreach ($records as $key) { ?>
<li class="siteli"> <a href="#" class="add">
<div id="site-icon"><img src="<?php echo $key->site_img; ?>" width="16" height=""></div>
<p id="text-site"> <?php echo $key->site_name; ?></p>
</li>
<?php } ?>
</ul>
</fieldset>
Run Code Online (Sandbox Code Playgroud)
现在我试图通过添加A,B,C等作为标题按字母顺序对结果进行分组.
例,
A
Amazon
Aol
Aol Mail
B
Bing
Bogger
Run Code Online (Sandbox Code Playgroud)
您可以使用数组排序对数组进行排序.在你的情况下,我会选择sort()
现在,我将使用前面的字母显示链接:
<?php
$records = ['Aaaaa', 'Aaaa2', 'bbb', 'bbb2', 'Dddd'];
$lastChar = '';
sort($records, SORT_STRING | SORT_FLAG_CASE); //the flags are needed. Without the `Ddd` will come before `bbb`.
//Available from version 5.4. If you have an earlier version (4+) you can try natcasesort()
foreach($records as $val) {
$char = $val[0]; //first char
if ($char !== $lastChar) {
if ($lastChar !== '')
echo '<br>';
echo strtoupper($char).'<br>'; //print A / B / C etc
$lastChar = $char;
}
echo $val.'<br>';
}
?>
Run Code Online (Sandbox Code Playgroud)
这将输出类似的东西
A
Aaaa2
Aaaaa
B
bbb
bbb2
D
Dddd
Run Code Online (Sandbox Code Playgroud)
请注意,C缺失,因为没有以C开头的单词.