WonderCSS

如何让 WordPress 的搜索结果按照搜索词的相关性排序

通常情况下我们在 WordPress 网站里搜索一个关键词,默认的结果页面中日志是按照发布时间来排序的。这样即使我们搜索到了我们需要的结果,但要想找到最贴合的搜索结果也如大海捞针一样。我们其实有个办法可以让搜索结果按照相关性排列,这样就能更亲和用户。

打开主题的 functions.php 文件,插入下面这段代码:


// Search results page
if(is_search()){
    add_filter('posts_orderby_request', 'search_orderby_filter');
}
function search_orderby_filter($orderby = ''){
    global $wpdb;
    $keyword = $wpdb->prepare($_REQUEST['s']);
    return "((CASE WHEN {$wpdb->posts}.post_title LIKE '%{$keyword}%' THEN 2 ELSE 0 END) + (CASE WHEN {$wpdb->posts}.post_content LIKE '%{$keyword}%' THEN 1 ELSE 0 END)) DESC, {$wpdb->posts}.post_date DESC";
}

当然这也是相对亲和,毕竟对搜索结果的处理是个大学问,不然为毛baidu相对google要显得略弱者……这段代码只是考虑了最简单的情况,当文章标题含有关键字的时候给予权重值 2,内容里含有关键字的时候给予权重值 1,把两个权重值相加以后降序排列。然后才用文章发布时间降序作为候补排序方法,仅供参考。

By 于湛 发布于 2013.03.15 2,034 次浏览

发表评论

电子邮件地址不会被公开。 必填项已用*标注