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

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

最近有个客户找点启资源二次开发主题,需求是希望在搜索页面把标题包含指定关键词(不是用户搜索词)的文章排在前面。 下面点启资源给出相应代码: function erphp_custom_search_order($clauses, $query) { global $wpdb; if (!is_admin() &a...

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

下面点启资源给出相应代码:

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是某文章字段。

原文链接:https://www.dqzy.cn/2025/04/02/198.html,转载请注明出处。 1、本站所有源码资源(包括源代码、软件、学习资料等)仅供研究学习以及参考等合法使用,请勿用于商业用途以及违法使用。如本站不慎侵犯您的版权请联系我们,我们将及时处理,并撤下相关内容! 2、访问本站的用户必须明白,本站对所提供下载的软件和程序代码不拥有任何权利,其版权归该软件和程序代码的合法拥有者所有,请用户在下载使用前必须详细阅读并遵守软件作者的“使用许可协议”,本站仅仅是一个学习交流的平台。 3、如下载的压缩包需要解压密码,若无特殊说明,那么文件的解压密码则为:www.dqzy.cn。 4、点启资源网是一个免费且专业分享网站源码、图片素材、特效代码、教程文章、站长工具的平台。我们努力给站长提供好的资源!
0

评论0

请先
显示验证码
没有账号?注册  忘记密码?