功能介绍
搜索模式:有常规搜索和仅搜索文章标题两种模式。
搜索过滤:可以设置一些分类,让其不被搜索到。
搜索高亮:搜索结果页面,文章标题和缩略内容中的关键字高亮显示。
注意:缩略内容使用<?php $this->excerpt(140, '...'); ?>
来截取的并不会高亮,因为这个地方没有插件接口,可以将这个函数换成插件内置的方法<?php $this->excerpts($this); ?>
,并且在插件设置里设置截取长度。也可以这样写个判断
<?php $all = Typecho_Plugin::export(); if(array_key_exists('Soso', $all['activated'])): ?> <?php $this->excerpts($this); ?>//插件启动就调用插件的这个方法 <?php else: ?> <?php $this->excerpt(140, '...'); ?>//插件没启动就调用默认方法 <?php endif; ?>
下载后将 soso 文件夹传到 typecho 目录下,然后启动插件,打开插件设置,根据文字提示设置即可。
禁用旧版插件,删除旧版插件文件夹,然后上传最新版插件,启动插件设置插件即可
typecho 按分类搜索文章
之前我写的 soso 搜索增强插件其实已经能够根据分类进行搜索内容了,不过需要模板上进行配合,比如我们搜索分类id
为2620
下关于typecho
的文章,需要传递分类id
的参数给cat
,让插件获取,比如这个链接https://qqdie.com/search/typecho/?cat=2620
,插件会获取到2620
,然后根据它来按分类搜索文章内容。
那么问题来了,模板搜索表单怎么传递cat
参数
typecho 默认的搜索结构直接加个input
进行传递,如下:
<form method="post" action="<?php $this->options->siteUrl(); ?>" role="search"> <input type="hidden" name="cat" value="2620"> <input type="text" name="s" placeholder="Search..."> <button type="submit">Search</button> </form>
HTML
经过测试并没有用,因为在处理搜索的过程中,typecho
的默认只接受name="s"
传递的内容。
我的解决方案就是跳过typecho
默认的搜索处理函数,然后自己写。
把上述代码中的name="s"
改成name="ss"
,跳过 typecho 默认的搜索处理函数。代码如:
<form method="post" action="<?php $this->options->siteUrl(); ?>" role="search"> <input type="hidden" name="cat" value="2620"> <input type="text" name="ss" placeholder="Search..."> <button type="submit">Search</button> </form>
HTML
在functions.php
模板文件里加入
function themeInit($archive) { if($archive->request->isPost() && isset($archive->request->ss)){ so($archive);//判断为 post 请求,并且有参数 ss,启用 so 函数 }} function so($obj){ $url=$obj->options->index; if (Helper::options()->rewrite==0){$url=Helper::options()->rootUrl.'/index.php/';} /** 处理搜索结果跳转 */ if (isset($obj->request->ss)) { $filterKeywords = $obj->request->filter('search')->ss;//获取搜索词 $cat = $obj->request->filter('search')->cat;//获取分类 id /** 跳转到搜索页 */ if (NULL != $filterKeywords) { $obj->response->redirect(Typecho_Router::url('search', array('keywords' => urlencode($filterKeywords)),$url)."?cat=".$cat);//设置跳转地址 } } }
PHP
下载soso
插件并启用插件,测试效果,有效果就可以进行下一步骤了。
上面的操作完成后,你会发现翻页按钮的链接并不携带cat
参数,也就是说一旦翻页了,这个按分类搜索就失效了。所以我们需要给翻页按钮追加参数,我最初采用的是 js 追加参数,后来发现可以直接重写分类按钮的链接,所以就采用 php 修改按钮链接的方式追加参数了。
在搜索结果的模板文件中增加以下代码即可:
<?php global $can;//定义全局变量,方便下面获取 $cat=intval($this->request->cat);//获取 cat if($cat>0){$can='?cat='.$cat;}else{$can="";} class Typecho_Widget_Helper_PageNavigator_Classic extends Typecho_Widget_Helper_PageNavigator { public function prev($prevWord = 'PREV') { //输出上一页 if ($this->_total > 0 && $this->_currentPage > 1) { echo '<a class="prev" href="'%20.%20str_replace($this->_pageHolder,%20$this->_currentPage%20-%201,%20$this->_pageTemplate)%20.%20$this->_anchor%20.%20$GLOBALS['can']%20.%20'">' . $prevWord . '</a>'; } } public function next($nextWord = 'NEXT') { //输出下一页 if ($this->_total > 0 && $this->_currentPage < $this->_totalPage) { echo '<a class="next" title="" href="'%20.%20str_replace($this->_pageHolder,%20$this->_currentPage%20+%201,%20$this->_pageTemplate)%20.%20$this->_anchor%20.%20$GLOBALS['can']%20.%20'">' . $nextWord . '</a>'; } } } ?>
PHP
上述代码就是在上一页/下一页的翻页按钮后面追加cat
参数,追加好了,就完美了。
步骤 1 中的代码只是简单的传递了一个分类 id,并不适合实际中使用,可以改为如下:
<form method="post" action="<?php $this->options->siteUrl(); ?>" role="search"> <select name="cat"> <option value="0" selected>全部</option> <option value="2619">Typecho 全部</option> <option value="2620">Typecho 主题</option> <option value="2621">Typecho 插件</option> <option value="2626">Typecho 教程</option> <option value="2618">博客文章</option> </select> <input type="text" name="ss" placeholder="Search..."> <button type="submit">Search</button> </form>
HTML
使用select
能够比较方便的选择分类进行搜索,根据需要select
里面的内容可以使用循环输出所有分类。
还没有人赞赏,快来当第一个赞赏的人吧!
- 2¥
- 5¥
- 10¥
- 20¥
- 50¥