WP ACF - объединение различных полей / затем цикл с WP Query - PullRequest
1 голос
/ 14 октября 2019

Я часами искал решение моей проблемы. Я не мог найти ничего похожего на то, чего я пытаюсь достичь. Поэтому я действительно застрял и ценю любую помощь!

У меня есть CPT, называемый «журнал», с несколькими полями ACF. Одно поле ACF - это год, когда журнал был опубликован. Другое поле - это номер журнала, который похож на уникальный идентификатор. Каждый год выходит несколько журналов.

То, чего я пытаюсь добиться, - это вывод, который дает мне элемент «ul» для каждого «года» и «li» для каждого «номера журнала», который был опубликован в соответствующем «году»,

Например, вот так:

<ul class="2019">
   <li>200</li>
   <li>199</li>
   <li>198</li>
   <li>197</li>
   <li>196</li>
</ul>

<ul class="2018">
   <li>195</li>
   <li>194</li>
   <li>193</li>
   <li>192</li>
   <li>191</li>
</ul>

Понятия не имею, логично, как решить эту проблему. Как можно перекрестно ссылаться на поля, сократить все поля «год» (которых несколько) до одного вывода, а затем вывести все «номера журнала», опубликованные в конкретном году, а затем вывести несколько списков для каждого года, как показано выше?

Ответы [ 2 ]

0 голосов
/ 15 октября 2019

Мне удалось получить желаемые результаты с помощью вашего ввода @ DubVader

Вот код, который я использовал:

<?php foreach($magazine_year as $option ){

    $args = array(

        'post_type' => 'magazine',
        'meta_key' => 'year',
        'meta_value' => $option

     );

$the_query = new WP_Query( $args ); ?>

<?php if( $the_query->have_posts() ):

     ?>
    <ul class="<?php echo $option; ?>">
    <?php while( $the_query->have_posts() ) : $the_query->the_post(); ?>
        <li>
                <?php the_field('magazine_number'); ?>
        </li>
    <?php endwhile; ?>
    </ul>
<?php endif; }?>

<?php wp_reset_query();  // Restore global post data stomped by the_post(). ?>    
0 голосов
/ 14 октября 2019

Вы можете попробовать что-то вроде этого. Мне кажется, вам нужно сначала получить все годы, а затем выполнять запросы для каждого года, чтобы получить номера журналов. Я не уверен, насколько интенсивно это будет на вашем сервере, вам просто нужно попробовать. Возможно, придется настроить для ваших имен полей.

<?php

global $post;

$args = array(

   'post_type' => 'magazine'

);

$posts = new WP_Query($args); // Query posts of 'magazine' post type

$magazine_years = array(); // set up array to put years in

if ($posts) {

   foreach ($posts as $post) {

      setup_postdata( $post );

      $the_year = get_field('year'); // get the value of year field
      $magazine_years[] = $the_year; // add year to the array

   }


}

wp_reset_postdata(); // reset the query so we dont introduce a problem with more queries

foreach ($magazine_years as $year) {

// do a query for each year

   $args = array(

      'post_type' => 'magazine',
      'meta_key' => 'year',
      'meta_value_num' => $year

   );

   $posts = new WP_Query($args);

   if ($posts) { ?>

  <!-- create your list -->

    <h1><?php echo $year; ?></h1>
    <ul class="<?php echo $year; ?>">

<?php foreach($posts as $post) {

         setup_postdata( $post );
         <li><php the_field('magazine_number'); ?></li>

      } ?>

    </ul>

<?php   

  }

 // reset the query data so you can run another without issue

  wp_reset_postdata();

}
...