WordPressで新着記事を「カテゴリー名表示+色分け」で表示したいという記事を投稿しましたが、カスタム投稿の場合、またちょっと記述が変わるのでカスタム投稿バージョンをご紹介します。
カスタム投稿タイプで記事を投稿しており、タームをカテゴリーのように使用している場合に有効です。
テンプレートの記述
カスタム投稿(custom)の新着記事を5件表示
<?php query_posts("post_type=custom&showposts=5&paged=".$paged); ?>
<?php if(have_posts()): ?>
<ul>
<?php while(have_posts()): the_post(); ?>
<li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a><span class="ymd">(<?php the_time('Y年m月d日'); ?>)</span></li>
<?php endwhile; ?></ul>
<?php else: ?>
<p>現在投稿記事はありません。</p>
<?php endif; ?>
タクソノミー(cus-tax)のタームを取得
<?php $terms = wp_get_object_terms($post->ID, 'cus-tax'); ?>
<span class="タームスラッグ名">でターム名を囲む
<span class="<?php echo "$term->slug"; ?>"><?php echo "$term->name" ?></span>
foreachと共にテンプレートに追加
<?php query_posts("post_type=custom&showposts=5&paged=".$paged); ?>
<?php if(have_posts()): ?>
<ul>
<?php while(have_posts()): the_post(); ?>
<?php $terms = wp_get_object_terms($post->ID, 'cus-tax'); ?>
<?php foreach($terms as $term): ?>
<li><span class="<?php echo "$term->slug"; ?>"><?php echo "$term->name" ?></span><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a><span class="ymd">(<?php the_time('Y年m月d日'); ?>)</span></li>
<?php endforeach; ?>
<?php endwhile; ?>
</ul>
<?php else: ?>
<p>現在投稿記事はありません。</p>
<?php endif; ?>
表示HTML
<ul> <li><span class="term-a">タームA</span> <a href="/">記事タイトル1</a><span class="ymd">(2013年12月20日)</span></li> <li><span class="term-a">タームA</span> <a href="/">記事タイトル2</a><span class="ymd">(2013年12月15日)</span></li> <li><span class="term-c">タームC</span> <a href="/">記事タイトル3</a><span class="ymd">(2013年12月09日)</span></li> <li><span class="term-b">タームB</span> <a href="/">記事タイトル4</a><span class="ymd">(2013年12月09日)</span></li> <li><span class="term-c">タームC</span> <a href="/">記事タイトル5</a><span class="ymd">(2013年11月29日)</span></li> </ul>
CSS
ul {
list-style: none;
margin: 0;
padding: 0;
}
ul li {
clear: both;
margin: 0 0 1em;
}
ul li span {
display: block;
float: left;
width: 4em; /*ターム名による*/
margin: 0 10px 10px 0;
padding: 5px;
text-align: center;
font-size: 10px;
}
ul li span.term-a {
background: #e3efef;
}
ul li span.term-b {
background: #efe3ec;
}
ul li span.term-c {
background: #efefe3;
}
ul li span.ymd {
display: inline;
float: none;
padding: 0 5px;
font-size: 13px;
color: #999;
}







最近のコメント