wordpress - WooCommerce、wordpress 搜索、pre_get_posts 过滤器排除摘录和产品描述
问题描述
我正在尝试通过使用 pre_get_posts 挂钩来修改自定义 wordpress 搜索,以便不会在产品描述中搜索特定单词。
add_action( 'pre_get_posts', 'exclude_search_content' );
function exclude_search_content( $Q ) {
$search_phrase = $Q->query['s'];
if( $Q->is_search() ) {
/** Dont search for $search_phrase in excerpt and product description
* search only product title, a meta key and a taxonomy.
*/
}
}
它似乎比我预期的要复杂。有任何想法吗?
解决方案
如果您查看posts_search 参考资料 ,您会发现一些Contribute 已经编写了类似的功能,所以我只是对其进行了测试,它工作正常。
function search_by_title_only($search, $wp_query)
{
global $wpdb;
if (empty($search)) {
return $search; // skip processing - no search term in query
}
$q = $wp_query->query_vars;
$n = !empty($q['exact']) ? '' : '%';
$search =
$searchand = '';
foreach ((array) $q['search_terms'] as $term) {
$term = esc_sql($wpdb->esc_like($term));
$search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')";
$searchand = ' AND ';
}
if (!empty($search)) {
$search = " AND ({$search}) ";
if (!is_user_logged_in()) {
$search .= " AND ($wpdb->posts.post_password = '') ";
}
}
return $search;
}
add_filter('posts_search', 'search_by_title_only', 20, 2);
推荐阅读
- sql - 从不同的表中选择多行到一列
- typescript - 为什么要导出同名的类和命名空间?
- python - YOLOv5 throws a duplicate labels error even though all labels are unique
- python - 如何使用列表理解在两个列表之间创建重复项列表?
- postman - 使用 csv 文件的 Postman 测试脚本
- java - 如何在 JAVA JSP 页面上检索结果集?
- python - 在可滚动框架内使用 place 方法
- reactjs - 在同一路由路径上使用 2 个不同的组件来显示弹出窗口
- google-cloud-firestore - Cloud Run 错误:容器无法启动。无法启动并监听 PORT 定义的端口
- javascript - 没有地图的地理编码地球自动完成框