[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>
效果:
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。