我正在编写一个Wordpress查询来过滤搜索结果。
我想使用模板logged_in_mentor_only_template.php
,logged_in_only_template.php
(以及两个受限制的类别)删除结果。
此查询有效但仍停止返回任何帖子。非常奇怪,页面被退回但帖子不是。 (我还没有添加类别过滤,因为我没有要过滤的帖子!)
我尝试添加post_type过滤器,其中列出了帖子和页面,但仍然没有。
任何帮助表示感谢。
query_posts(array_merge($wp_the_query->query, array(
'meta_query' => array(
array(
'key' => '_wp_page_template',
'value' => 'logged_in_mentor_only_template.php',
'compare' => '!='
),
array(
'key' => '_wp_page_template',
'value' => 'logged_in_only_template.php',
'compare' => '!='
)
)
)));
答案 0 :(得分:0)
您搜索_wp_page_template
帖子不会有任何_wp_page_template
所以它只会获取页面。因为它只会返回设置为_wp_page_template
的帖子/页面。
因此,您需要检查不存在的元键。
在WP 3.5中,将添加compare值'NOT EXISTS'。
直到3.5我会建议以下工作。 不要添加这些元查询值。但是在循环中检查它们:
while (the_posts()): the_post();
if (get_post_meta(GET_THE_ID(), '_wp_page_template', true) == 'logged_in_mentor_only_template.php' || get_post_meta(GET_THE_ID(), '_wp_page_template', true) == 'logged_in_mentor_only_template.php')
continue; // skipp the rest of this round
//Do the rest of your loop
endwhile;
第二个选项是获取执行所有帖子的所有帖子 从此查询中获取所有ID 然后执行一个新的wp_query,其中排除先前获取的查询的ID。
最佳选择
这些解决方案对性能不利
最好的选择是等待几周的WP 3.5,它应该在12月的某个地方发布。