Rub*_*ben 6 php wordpress search wordpress-plugin
我想在WordPress搜索结果中添加/注入/追加额外的结果.
目前,WordPress只允许您"调整"在其自己的数据库上执行的查询,但不允许您修改(或在WordPress术语中,过滤)结果数组.
即:如果在WordPress中我搜索"马铃薯"一词,所有与此术语相关的帖子都会回来.我想将通过不同服务获得的结果包含在WordPress结果集中.
只是为了澄清,我从第三方API调用中得到了我的结果.不是来自WordPress数据库.
有没有人知道如何做到这一点?
编辑:最好这需要在我的WordPress插件中进行,而无需更改搜索模板.
您可以使用pre_get_posts添加/编辑搜索结果而无需更改搜索模板.
排除搜索结果中的网页.可以通过仅显示帖子的结果来创建限制搜索结果的操作挂钩.
以下示例演示了如何执行此操作:
function search_filter($query) {
if ( !is_admin() && $query->is_main_query() ) {
if ($query->is_search) {
$query->set('post_type', 'post');
}
}
}
add_action('pre_get_posts','search_filter');
Run Code Online (Sandbox Code Playgroud)
function search_filter($query) {
if ( !is_admin() && $query->is_main_query() ) {
if ($query->is_search) {
$query->set('post_type', array( 'post', 'movie' ) );
}
}
}
add_action('pre_get_posts','search_filter');
Run Code Online (Sandbox Code Playgroud)
function search_filter() {
if ( is_search() ) {
// Do your API call here
// Save retrieved data in your wordpress
// This will also help to you avoid api call for repeated queries.
$post_id = wp_insert_post( $post, $wp_error ); // wp_insert_post() // Programatically insert queries result into your wordpress database
array_push( $query->api, $post_id );
}
}
add_action('pre_get_posts','search_filter');
function have_posts_override(){
if ( is_search() ) {
global $wp_query;
$api_post = $wp_query->api;
foreach ($api_post as $key) {
// This will enable you to add results you received using API call
// into default search results.
array_push($wp_query->posts, $key);
}
}
}
add_action( 'found_posts', 'have_posts_override' );
Run Code Online (Sandbox Code Playgroud)
这个问题可能很老了,但我也遇到了类似的问题,将来也可能有人遇到这样的问题,所以我会发布我的(更好的)解决方案。
如上所述,将 api 查询结果保存在 wp_posts-table 中(可能作为自定义帖子类型)并对它们执行正常的 WP-Search 是最干净的解决方案。
但就我而言,我必须处理另一个表,该表缓存了一些外部数据并将其链接到现有帖子的 ID,并且我无法更改此结构。
因此,Abhineet Verma 的解决方案(search_filter + pre_get_posts)一开始看起来很有用,但最终它不适合我。我能够向查询结果添加其他帖子,但它们不适合结果的正常分页。例如,如果您想每页显示 10 个结果,并使用上述解决方案并从 api 获取 20 个结果,则每页将有 30 个结果:属于该页面的 10 个正常结果加上每个页面上的全部 20 个结果。它还破坏了一些分页插件。
所以我最终解决了这个问题如下。我使用过滤器 posts_search 来扩展 sql 查询:
add_filter('posts_search', function($sql) {
if (!$sql) {
return $sql;
}
global $wpdb;
$sqst = "select id from {$wpdb->prefix}mytable ... bla bla -> query to my custom table, wich return a bunch of IDs";
$sqlr = "AND (({$wpdb->prefix}posts.ID in ($sqst)) or (1 = 1 $sql))";
return $sqlr;
});
Run Code Online (Sandbox Code Playgroud)
它看起来有点奇怪,但效果很好。也许有时会对某人有所帮助!
| 归档时间: |
|
| 查看次数: |
5140 次 |
| 最近记录: |