wordpress 搜索结果按标题是否包含某额外指定关键词排序

7次阅读
没有评论

共计 1186 个字符,预计需要花费 3 分钟才能阅读完成。

最近有个客户找 模板兔 二次开发主题,需求是希望在搜索页面把标题包含指定关键词 (不是用户搜索词) 的文章排在前面。

下面 模板兔 给出相应代码:

function erphp_custom_search_order($clauses, $query) {
global $wpdb;

if (!is_admin() && $query->is_search) {
$search_title_first_keyword = _MBT('search_title_first_keyword');

$clauses['orderby'] = "
CASE 
WHEN {$wpdb->posts}.post_title LIKE '%{$search_title_first_keyword}%' THEN 0 
ELSE 1 
END ASC,
{$wpdb->posts}.post_date DESC
";
}
return $clauses;
}
add_filter('posts_clauses', 'erphp_custom_search_order', 10, 2);

其中 $search_title_first_keyword 就是额外指定的关键词。

如果是按标题或某个文章字段包含此指定关键词:

function erphp_custom_search_order($clauses, $query) {
global $wpdb;

if (!is_admin() && $query->is_search) {
$search_title_first_keyword = _MBT('search_title_first_keyword');

$order_sql = "
CASE 
WHEN ({$wpdb->posts}.post_title LIKE '%{$search_title_first_keyword}%' 
OR {$wpdb->postmeta}.meta_value LIKE '%{$search_title_first_keyword}%'
) THEN 0 
ELSE 1 
END ASC
";

$clauses['join'] .= "LEFT JOIN {$wpdb->postmeta} ON ({$wpdb->posts}.ID = {$wpdb->postmeta}.post_id AND {$wpdb->postmeta}.meta_key ='erphp_search_title')";

$clauses['orderby'] = $order_sql . ", {$wpdb->posts}.post_date DESC";

$clauses['groupby'] = "{$wpdb->posts}.ID";
}
return $clauses;
}
add_filter('posts_clauses', 'erphp_custom_search_order', 10, 2);

其中 erphp_search_title 是某文章字段。

全文结束
 0
有趣源码
版权声明:本站原创文章,由 有趣源码 于 2025-10-19 发表,共计 1186 字。
转载说明:除特殊说明外本站文章皆由 CC-4.0 协议发布,转载请注明出处。特别声明:本站所有资源或内容,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
评论 (没有评论)