您的位置:首页 > 编程语言 > PHP开发

[thinkPHP5项目实战_26]前台文章关键词搜索

2017-11-11 23:20 531 查看
每篇文章下面展示有关键词,点击关键词可以查询该栏目下的所有具有该关键词的文章;

点击关键词,需要将该关键词当做参数传值tahs控制器进行联表查询;

在index模块下新建控制器Tags.php:

<?php
namespace app\index\controller;
class Tags extends Basic
{
public function index()
{
$tags=input('tags');//获取传过来的关键词
$map=['a.keywords' => ['like','%'.$tags.'%']];//拼接查询关键词的语句
//联表查询article表中所有与用户搜索相同的关键词的该栏目下的文章,,2篇文章为一页;按照文章的artid进行排序
$artres= \think\Db::name('article')->alias('a')->join('cate c','c.ID = a.cateid','LEFT')->field('a.artid,a.title,a.pic,a.time,a.desc,a.click,a.keywords,c.catename')->order('a.artid desc')->where($map)->paginate(2);
$this->assign('artres',$artres);
return $this->fetch('tags');//返回模板tags.html
}
}


查询到的文章需要展示到对应的模板上;

新建视图文件Tags/tags.html:

与Lists/lists.html代码一样,拷贝即可

<body>
{include file="Public/header" /}
<div class="container">
<div class="row">
<div class="col-sm-8 blog-main">
{volist name="artres" id="vo"}
<div class="post multi-post cate2 auth1">
<h4 class="post-date">{$vo.time|date="Y年m月d日",###}</h4>
<h2 class="post-title"><a href="{:url('Article/index',array('artid'=>$vo['artid']))}">{$vo.title}</a></h2>
<div class="post-body"><p>{$vo.desc}</p>
{if condition="$vo['pic'] neq ''"}
<p style="text-indent: 0em;"><a title="2016年就一个字:戒!" target="_self" href="{:url('Article/index',array('artid'=>$vo['artid']))}"><img src="__PUBLIC__{$vo.pic}" title="你我网" alt="你我网"/></a></p>
{/if}
</div>

<h5 class="post-tags">Tags: <span class="tags">
<?php
$arr=explode(',', $vo['keywords']);
foreach ($arr as $k => $v) {
echo "<a href='http://localhost/test/tp5/Public/index.php/index/Tags/index/tags/$v'>$v</a>";
echo ' ';
}
?>
</span></h5>
<h6 class="post-footer">
发布:渣渣 | 分类:{$vo.catename} | 评论:666 | 浏览:{$vo.click} | <a href="{:url('Article/index',array('artid'=>$vo['artid']))}">阅读全文 > </a>
</h6>
</div>
{/volist}
<div class="post pagebar">{$artres->render()}</div>
</div>
{include file="Public/sidebar"}
</div>
</div>
{include file="Public/footer" /}
</body>


效果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: