其实我是想在博客实现一个作者专栏页面的,但是技术难度有点大,因为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 '
  • '.$post_title.'
  • '; } } }else{ echo '请设置要调用的作者ID'; } }

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

    模板上的调用代码如下:

    author->uid);?>

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

    TAGS:Typecho注册
    !如链接失效请在下方留言。本站所有资源均来源于网络,版权属于原作者!仅供学习参考,本站不对您的使用负任何责任。如果有侵权之处请第一时间联系我们删除,敬请谅解!