typecho调用作者最近文章列表及数量设置。

其实我是想在博客实现一个作者专栏页面的,但是技术难度有点大,因为typecho的限制摆在这里,想要做出来得费很多心思了,而最近的时间也确实没有之前那么充裕,所以这个功能就往后推了。现在博客是退而求其次的,在文章的阅读页面右侧展示了一个作者的基本信息,并且调用了最新发布的十篇文章,我还是简单的记录一下实现的原理。

主要是在function.php中定义功能的实现,做数据库的查询。

代码如下:

/* 输出该作者最近文章列表 /
function authorPosts($authorid){
    if($authorid){ 
        $limit = 6;
        $db = Typecho_Db::get();
        $result = $db->fetchAll($db->select()->from('table.contents')
            ->where('authorId = ?',$authorid)
            ->where('status = ?','publish')
            ->where('type = ?', 'post')
            ->limit($limit)
            ->order('cid', Typecho_Db::SORT_DESC)        
        );
        if($result){
            foreach($result as $val){                
                $val = Typecho_Widget::widget('Widget_Abstract_Contents')->push($val);
                $post_title = htmlspecialchars($val['title']);
                $permalink = $val['permalink'];
                echo '<li><a href="'.$permalink.'" title="'.$post_title.'" target="_blank"><i class="iconfont icon-sanjiao"></i>'.$post_title.'</a></li>';
            }
        }
    }else{
        echo '请设置要调用的作者ID';
    }
}

实现的原理就是,定义一个方法,接收页面上传过来的作者ID参数,然后通过这个参数查询数据库里的文章表,并限制数量为6调,随后将查询出的数组循环输出到页面上,就实现了整个流程。

模板上的调用代码如下:

<?php authorPosts($this->author->uid);?>

其实这个功能还可以进一步的开发,比如传两个参数,作者ID和限制条数,这样就可以进一步的方便控制了。(来源:乐奇网)