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和限制条数,这样就可以进一步的方便控制了。
文章由官网发布,如若转载,请注明出处:https://www.veimoz.com/48
0 评论
3.2k
发表评论
热门文章
自媒体博客Spimes主题34w 阅读
Spimes主题专为博客、自媒体、资讯类的网站设计....
vCard主题个人简历主题13w 阅读
一款个人简历主题,可以简单搭建一下,具体也比较简单....
Splity博客双栏主题11w 阅读
仿制主题,Typecho博客主题,昼夜双版设计,可....
Spzac个人资讯下载类主题11w 阅读
用于作品展示、资源下载,行业垂直性网站、个人博客,....
热评文章
自媒体博客Spimes主题418 评论
Splity博客双栏主题187 评论
Spzac个人资讯下载类主题89 评论
Splinx博客图片主题35 评论
Spzhi知识付费社区主题34 评论
三栏清新博客S_blog主题30 评论
vCard主题个人简历主题29 评论
Pure轻简主题28 评论
尘集杂货铺和官网1t5-cn
11月11日
[已回复]
希望主题和播放器能支持SQLite数据库,AI能多个讯飞星火