Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/270.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/63.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP-为数组中的每个唯一值集生成HTML元素_Php_Mysql - Fatal编程技术网

PHP-为数组中的每个唯一值集生成HTML元素

PHP-为数组中的每个唯一值集生成HTML元素,php,mysql,Php,Mysql,我使用以下PHP脚本从MySQL DB表生成了一个: $result = mysqli_query($con,"SELECT * FROM city_list ORDER BY city_state"); echo "<ul class=\"chapter-list\">"; while($row = mysqli_fetch_array($result)) { echo "<li data-state=\"" . $row['city_state'] . "\"

我使用以下PHP脚本从MySQL DB表生成了一个:

$result = mysqli_query($con,"SELECT * FROM city_list ORDER BY city_state");

echo "<ul class=\"chapter-list\">";
  while($row = mysqli_fetch_array($result))
  {
  echo "<li data-state=\"" . $row['city_state'] . "\">" . $row['city_name'] . "</li>";
  }
echo "</ul>";

是否有一个PHP数组函数来做类似的事情,或者我可能不得不求助于JS?我已经浏览了PHP文档,但还没有找到解决方案。我是一名PHP初学者,因此非常感谢您的指导。

这里有一种方法。每次有一个新的$row['city_state'],if条件将为true,并且它将回显一个新的标题:

$last_state = '';

while($row = mysqli_fetch_array($result))
{
    if ($last_state != $row['city_state']){
        echo '<li>' . ucfirst($row['city_state']) . '</li>';
    }
    echo '<li data-state="' . $row['city_state'] . '">' . $row['city_name'] . '</li>';
    $last_state = $row['city_state'];
}

您可以将$row[city_state]的上一个值保存到while循环之外的变量中,并检查新的$row[city_state]是否等于旧的$row[city_state]。如果这两个值不相等,则添加如下项

编辑:
拉桑德斯的代码正是我的意思:

将查询更改为按城市州顺序选择DISTINCT*FROM city\u list Orders BY city\u state,可能吧?谢谢-效果很好!这是我的梦想!=你的代码中的诀窍是什么?是的,这就是我们给$last_state赋值的确切位置。它基本上是检查最后一个循环结束时的值与新加载行中的值之间的差异。第一次通过,$last_state也不等于新行,因此打印第一个标题。
<ul>
  <li>Alabama</li>
  <li data-state="alabama">Birmingham</li>
  <li data-state="alabama">Bear Creek</li>
  <li data-state="alabama">Belk</li>
  <li>Kansas</li>
  <li data-state="kansas">Topeka</li>
  <li data-state="kansas">Olathe</li>
</ul>
$last_state = '';

while($row = mysqli_fetch_array($result))
{
    if ($last_state != $row['city_state']){
        echo '<li>' . ucfirst($row['city_state']) . '</li>';
    }
    echo '<li data-state="' . $row['city_state'] . '">' . $row['city_name'] . '</li>';
    $last_state = $row['city_state'];
}