其实我是想在博客实现一个作者专栏页面的,但是技术难度有点大,因为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和限制条数,这样就可以进一步的方便控制了。(来源:乐奇网)
评论已关闭