我今天偶然发现了 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();
}