1

是否可以在 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>
4

1 回答 1

2

您正在寻找$articles根据article_id字段对数组进行排序 - 这可以使用函数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";
}
于 2013-08-11T00:37:09.067 回答