0

我今天偶然发现了 Codeigniter 的一个逻辑问题。4小时后,我想我最好在这里问一下。

我的项目主页包含:

  • 热门帖子(属性:标题、徽标、摘录)
  • 每个帖子的热门评论(属性:成员名称,头像)

我的问题是获得每个帖子的热门评论。

如果我不使用 Code Igniter,我将这样做:

<?php
foreach( $posts as $post ) {
    echo 'Post Title: '.$post['title'].'<br/>';

    $top_commenters = $this->get_top_commenters($post['id']);
    foreach( $top_commenters as $commenter ) {
        echo '<img src="'. $commenter['avatar'] .'"/><br/>';
    }
}

?>

我想你注意到我将每个帖子的 ID 传递给一个函数,以获取其最高评论者。但是,在 CodeIgniter 中,我无法从视图中调用控制器。

我将使用的最后一个解决方案是 Ajax。但我希望我能在这里得到一些帮助。

提前致谢!

更新:根据要求,这是我的模型函数和控制器函数:

//Model Function
function get_popular_posts() {

    $row = $this->db->query('
        SELECT * FROM posts
        INNER JOIN popular_posts ON posts.id = popular_posts.pid
        ORDER BY rank DESC LIMIT 6
    ');

    return $row->result_array();
}

//Model Function
function get_top_commenters($post_id){

    $row = $this->db->query('
        SELECT *
        FROM users
        WHERE username
        IN (
        SELECT username
        FROM comments WHERE pid = '. $post_id .')
        ORDER BY likes DESC LIMIT 6
    ');

    return $row->result_array();
}
4

2 回答 2

1

为什么要从视图中调用控制器函数?当您生成视图文件时,您的所有数据处理都应该已经完成​​。

将 $top_commenters 传递给控制器​​中的视图。

于 2013-07-30T11:04:59.390 回答
-6

您可以从视图中调用任何控制器: URL 示例:

<a href="controller_name/controller_function"> My URL </a> 
于 2013-07-30T11:03:15.503 回答