🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
昨天升级了一个隐藏的功能,今天就简单的做个说明怎么用,反正也不能浪费不是 那就用内容页面关键词读取相关内容为例吧。 前台是你模型中已经存在` keywords `字段  关键词支持 空格分割,号分割 那么就开始新功能之旅吧。 我们在 `application` 目录中新建一个 api目录 api目录再新建一个 index 目录 也就是` application\api\index ` 下面新建一个`Keywords.php` ~~~ <?php namespace app\api\index; /**  * 动态获取内容关键词并读取相关内容  * Class Keywords  * @package app\api\index  */ class Keywords{ public function index($text){ $cfg=unserialize($text['cfg']);         $biao=db($cfg['systype'].'_content')->where('id',$cfg['id'])->find(); // 查找这个内容的所在模型 $tags=db($cfg['systype'].'_content'.$biao['mid'])->where('id',$cfg['id'])->find(); //查找到模型后去模型表读取这个内容的信息 $detail=strpos($tags['keywords'],',')!==false?explode(',',$tags['keywords']):explode(' ',$tags['keywords']); //根据这个信息的 keywords 字段进行拆分检索 keywords 可以是自己定义的任意字段 $where=[]; $where_tit=[]; array_push($where_tit,'like'); $ARR=[]; for($i=0;$i<count($detail);$i++){ array_push($ARR,'%'.$detail[$i].'%'); } array_push($where_tit,$ARR); array_push($where_tit,'OR'); $where['title']=$where_tit; $array=db($cfg['systype'].'_content'.$biao['mid'])->where($where)->order($cfg['order'],$cfg['by'])->limit($cfg['rows'])->select(); foreach($array AS $k=>$rs){ $data[$k]['title']=$rs['title']; $data[$k]['create_time']=$rs['create_time']; $data[$k]['picurl']=tempdir($rs['picurl']); $rs['content']=preg_replace('/<([^<]*)>/is',"",$rs['content']); $data[$k]['content']=get_word($rs['content'],500); $data[$k]['url']=url($cfg['systype'].'/content/show',['id'=>$rs['id']],'html',true); } return $data; } } ~~~ 临时拼凑的代码bug难免 仅仅是示例。 怎么使用呢? `template\index_style\default\cms\content\pc\_show.htm` 强烈建议自己复制default一份再改不然升级会覆盖 在你需要的地方加上 ~~~ {qb:tag name="pc_show" rows="9" type="cms" union='id' class='app\\api\\index\\Keywords@index'} {$rs.title} {$rs.url} 内容网址 {$rs.title} 标题 {$rs.create\_time} 发布时间 {$rs.picurl}  图片 {$rs.content}  内容 {/qb:tag} rows 调用数量 type 调用的模块 你shop模块就写 =shop order 排序 ~~~ 是不是很好用 原理是union动态读取内容的id根据内容id查找所在模型和内容并把keywords拆分 用他作为关键词去查找内容。