在ID后对Foreach循环进行排序


Sort Foreach Loop after ID

是否可以在ID之后对foreach循环的结果进行排序?最高ID第一,依此类推…由于是文章,我希望最高ID(最新)第一:)

我的代码:

include_once('includes/connection.php');
include_once('includes/article.php');
$article = new Article;
$articles = $article->fetch_all();

?>
<html>
    <head>
        <title>CMS</title>
        <link rel="stylesheet" href="assets/style.css" />
    </head>
    <body>
        <div class="container">
            <a href="index.php" id="logo">CMS</a>
            <ol>
                <?php foreach ($articles as $article) { ?>
                    <li>
                        <a href="article.php?id=<?php echo $article['article_id']; ?>">
                            <?php echo $article['article_title']; ?>
                        </a>
                        - <small>
                            Posted <?php echo date('l jS', $article['article_timestamp']); ?>
                        </small>
                    </li>
                <?php } ?>
            </ol>
            <br />
            <small><a href="admin">Admin Login</a></small>
        </div>
    </body>
</html>

您要根据article_id字段对数组$articles进行排序,这可以使用函数usort来完成。

示例:

<?php
function cmp($a, $b)
{
    if ($a['article_id'] == $b['article_id']) {
        return 0;
    }
    return ($a['article_id'] < $b['article_id']) ? -1 : 1;
}

usort($articles, "cmp");
foreach ($articles as $article) {
    echo "$article: ". $article['article_id']." 'n";
}