dsc71976 2014-09-01 10:54
浏览 20
已采纳

通过自定义元日期订购帖子

Below is my code which loads a custom post type (show), for some reason whatever I change within the $args nothing changes with the order.

I would like to display shows in date order.

The custom field test_date is in the format of 20140907

Anyone able to shed some light?

 <?php 
    $args = array(
        'post_type' => 'show',
        'meta_key'  => 'test_Date',
        'orderby'   => 'meta_value_num',
        'order'     => 'DESC',
        'posts_per_page' => '-1'
    );
    query_posts($args);
    if (have_posts()) : while (have_posts()) : the_post(); ?>
        <?php
        $limit = 140;
        $display_from_date = get_post_meta( get_the_ID(), 'display_from_date', true );
        $display_to_date = get_post_meta( get_the_ID(), 'display_to_date', true );
        $book_online_link = get_post_meta( get_the_ID(), 'book_online_link', true );
        $show_description = get_post_meta( get_the_ID(), 'show_description', true );
        $date_formatted = get_post_meta( get_the_ID(), 'date_formatted', true );
        $show_content = get_the_content();
        $read_more = get_the_permalink();
        ?>

<div class="showbox">
  <div class="showthumb">
    <?php the_post_thumbnail('medium'); ?>
  </div>
  <div class="showdetails">
    <div class="showtitle"><?php the_title();?></div>
    <div class="showdate">
      <strong><?php echo $date_formatted; ?></strong>
    </div>
    <div class="clear"></div>
    <div class="showdescription">
      <br />
      <?php 
      if (empty($show_description)){
        echo '<em>No description available</em>';
      } else {
        if (strlen($show_description) > $limit)
        $show_description = substr($show_description, 0, strrpos(substr($show_description, 0, $limit), ' ')) . '... <a href="'. $read_more .'" style="font-size:10px; font-style: italic;">Read More</small>';
        echo $show_description;
      }
      ?>
    </div>
    <div class="clear"></div>

    <div class="showbuttons">
      <a href="<?php the_permalink(); ?>" class="moreinformation">More Information&nbsp;<IMG class='small_arrow_1_right' src='<?php bloginfo('template_url');?>/images/small_arrow_1_right.gif' alt='Next'>&nbsp;</a>
    </div>
    <div class="clear"></div>
  </div>
  <div class="clear"></div>
</div>

<?php endwhile; endif; wp_reset_query();  ?>
  • 写回答

1条回答 默认 最新

  • douwang4374 2014-09-01 12:00
    关注

    Its ok, I have managed to do it another way with SQL and that is working perfect!

    For reference:

    <?php
    
     $querydetails = "
       SELECT wposts.*
       FROM $wpdb->posts wposts, $wpdb->postmeta wpostmeta
       WHERE wposts.ID = wpostmeta.post_id
       AND wpostmeta.meta_key = 'test_date'
       AND wposts.post_status = 'publish'
       AND wposts.post_type = 'show'
       ORDER BY wpostmeta.meta_value ASC
     ";
    
     $pageposts = $wpdb->get_results($querydetails, OBJECT)
    
     ?>
    
    <?php if ($pageposts):
     foreach ($pageposts as $post):
           setup_postdata($post);
    
      $limit = 140;
      $display_from_date = get_post_meta( get_the_ID(), 'display_from_date', true );
      $display_to_date = get_post_meta( get_the_ID(), 'display_to_date', true );
      $book_online_link = get_post_meta( get_the_ID(), 'book_online_link', true );
      $show_description = get_post_meta( get_the_ID(), 'show_description', true );
      $date_formatted = get_post_meta( get_the_ID(), 'date_formatted', true );
      $show_content = get_the_content();
      $read_more = get_the_permalink();
      ?>
    
    <div class="showbox">
      <div class="showthumb">
        <?php the_post_thumbnail('medium'); ?>
      </div>
      <div class="showdetails">
        <div class="showtitle"><?php the_title();?></div>
        <div class="showdate">
          <strong><?php echo $date_formatted; ?></strong>
        </div>
        <div class="clear"></div>
        <div class="showdescription">
          <br />
          <?php 
          if (empty($show_description)){
            echo '<em>No description available</em>';
          } else {
            if (strlen($show_description) > $limit)
            $show_description = substr($show_description, 0, strrpos(substr($show_description, 0, $limit), ' ')) . '... <a href="'. $read_more .'" style="font-size:10px; font-style: italic;">Read More</small>';
            echo $show_description;
          }
          ?>
        </div>
        <div class="clear"></div>
    
        <div class="showbuttons">
          <a href="<?php the_permalink(); ?>" class="moreinformation">More Information&nbsp;<IMG class='small_arrow_1_right' src='<?php bloginfo('template_url');?>/images/small_arrow_1_right.gif' alt='Next'>&nbsp;</a>
        </div>
        <div class="clear"></div>
      </div>
      <div class="clear"></div>
    </div>
    
     <?php endforeach;
    endif; ?>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 怎样才能让鼠标沿着线条的中心线轨迹移动
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?
  • ¥15 win10权限管理,限制普通用户使用删除功能
  • ¥15 minnio内存占用过大,内存没被回收(Windows环境)
  • ¥65 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?