按自定义字段值对查询中的帖子进行分组

Group posts in query by custom field value

我正在处理一个将 FacetWP 用于活动位置页面的网站,但一个关键功能无法正常工作。去年,另一位开发人员设置了一个自定义解决方案来列出 FacetWP 帖子并按它们所处的状态对它们进行排序。他们为此使用了自定义分类法,但从那时起,插件和 is map add-on 已经有了破坏该解决方案的更新。

FacetWP 背后的开发人员一直在帮助我修改自定义解决方案,但他现在不在,我仍然需要一些帮助。他指示我重做查询以删除自定义分类法并使用自定义字段代替状态名称,因为这与插件一起使用效果更好。因此,此模板的查询如下所示:

<?php
return array(
  'post_type' => 'location',
  'post_status' => 'publish',
  'posts_per_page' => -1,
  'order' => 'ASC',
  'meta_key' => 'state',
  'orderby' => array(
    'meta_value' => 'ASC',
    'title' => 'ASC',
  ),
);

这部分效果很好,解决了我之前遇到的一个问题。我像这样重建了模板的显示代码:

<?php
while ($query->have_posts()) {
    $state = get_field('state');
    $show_header = (empty($prev_state) || $state != $prev_state);
    $prev_state = $state;

    $query->the_post();
    $post_id = get_the_ID();
    $title = get_the_title($post_id);
    $distance = facetwp_get_distance($post_id);
    $distance = (false !== $distance) ? round($distance, 1) . ' miles away' : '';
    $coords = get_post_meta($post_id, 'location', true);
    $content = get_the_content();
    ?>
  <?php if ($show_header): ?>
  <h1 class="state-name"><?php echo esc_html($state); ?></h1>
  <?php endif;?>

  <div class="post-item" data-title="<?php echo esc_attr($title); ?>"
      data-latitude="<?php echo $coords['lat']; ?>" data-longitude="<?php echo $coords['lng']; ?>"
      data-distance="<?php echo $distance; ?>">
    <div class="post-item-content">
      <h2><?php echo $title; ?></h2>
      <?php echo $content; ?>
    </div>
  </div>
  <?php
}

    wp_reset_query();
?>

您可以从 the staging server where I'm testing this 看出它几乎可以正常工作,但不是 100% 正确。帖子未按州正确列出,并且列表上方的州标题不正确。

这是漫长的一天,我的大脑只是没有看到我需要做些什么来纠正这个问题。我绝对可以在正确的方向上使用微调。

我终于修好了:

<?php

    $state_posts = array();

    while ($query->have_posts()) {
        $query->the_post();
        $state = get_post_meta(get_the_ID(), 'state', true);
        $state_posts[$state][] = $post;
    }

    wp_reset_query();

    foreach ($state_posts as $state_post => $state_title) {
?>
  <h1 class="state-name"><?php echo esc_html($state_post); ?></h1>
<?php
  foreach ($state_title as $listing => $single_listing) {
    setup_postdata($single_listing);
    $post_id = $single_listing->ID;
    $title = get_the_title($post_id);
    $distance = facetwp_get_distance($post_id);
    $distance = (false !== $distance) ? round($distance, 1) . ' miles away' : '';
    $coords = get_post_meta($post_id, 'location', true);
    $content = get_the_content();
?>
  <div class="post-item" data-title="<?php echo esc_attr($title); ?>" data-latitude="<?php echo $coords['lat']; ?>" data-longitude="<?php echo $coords['lng']; ?>" data-distance="<?php echo $distance; ?>">
    <div class="post-item-content">
      <h2><?php echo $title; ?></h2>
      <?php echo $content; ?>
    </div>
  </div>
<?php
  }
  wp_reset_postdata();
}

我在 while 循环中有 post 数据,如 the_titlethe_content 等,而我在最后 foreach 需要它循环以便仅将它们应用于个人 posts.