[thinkPHP5项目实战_26]前台文章关键词搜索
每篇文章下面展示有关键词,点击关键词可以查询该栏目下的所有具有该关键词的文章;
点击关键词,需要将该关键词当做参数传值tahs控制器进行联表查询;
在index模块下新建控制器Tags.php:
<?php
namespace appindexcontroller;
class Tags extends Basic
{
public function index()
{
$tags=input("tags");//获取传过来的关键词
$map=["a.keywords" => ["like","%".$tags."%"]];//拼接查询关键词的语句
//联表查询article表中所有与用户搜索相同的关键词的该栏目下的文章,,2篇文章为一页;按照文章的artid进行排序
$artres= hinkDb::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>效果:
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
