例えばショッピングサイト等での話です。商品のカテゴリー一覧ページで、カテゴリーごとに任意の文字列を表示したい場合。いくつか方法があると思いますが、スマートなやり方をメモってみます。2013年09月08日追記:もっと良い方法がありました。プラグインを使って簡単に出来ますのでリンクを貼っておきます。【WordPress】カテゴリーページでカテゴリー毎に任意の画像や文章をプラグインで表示させるカテゴリーごとに任意の文章を表示する方法2つ方法は他にもあると思いますが、とりあえず2つ挙げてみます。カテゴリーの説明欄を表示する画像を表示する予定が無いならコレが一番です。<?php echo category_description(); ?>この記述でカテゴリーの説明欄を表示することが出来ます。カテゴリーごとにカスタムフィールドを用意し、それを表示する画像も文章も表示するならこれが本当にスマート。カテゴリーにカスタムフィールドを実装する方法は既に公開しているサイト様があるのですが、そこに書かれているソースを少々弄らせて頂きましたので記述します。カテゴリーにカスタムフィールドを実装WordPressのカテゴリーにカスタムフィールドを追加する | webOpixel カテゴリーごとに独自の画像やテキストを表示させたい場合、テンプレートで条件分岐を使用すれば簡単ですが、それだとカテゴリーが増える度にテン...まず、こちらを見ながらソースを記述していきます。とても分かりやすく解説されております。こちらを参考に、自分なりに修正したソースのみ記述します。カテゴリー編集に項目を追加add_action ( 'edit_category_form_fields', 'extra_category_fields');function extra_category_fields( $tag ) {$t_id = $tag->term_id;$cat_meta = get_option( "cat_$t_id");?><tr class="form-field"><th><label for="extra_text">その他テキスト</label></th><td><textarea name="Cat_meta[extra_text]" id="extra_text"><?php if(isset ( $cat_meta['extra_text'])) echo esc_html($cat_meta['extra_text']) ?></textarea></td></tr><tr class="form-field"><th><label for="upload_image">画像URL</label></th><td><input id="upload_image" type="text" size="36" name="Cat_meta[img]" value="<?php if(isset ( $cat_meta['img'])) echo esc_html($cat_meta['img']) ?>" /><br />画像を追加: <img src="images/media-button-other.gif" alt="画像を追加" id="upload_image_button" value="Upload Image" style="cursor:pointer;" /></td></tr><?php}修正した箇所は8,9,10行目。単純に<input>タグから<textarea>に変えました。複数行に渡って文章を入力するためです。テンプレートファイルでの表示上記のサイトではリストで全てのカテゴリーを表示していたので、現在のカテゴリー情報のみ表示させます。<ul class="clearfix"><?php$categoryname = single_cat_title('',false);$categoryid = get_cat_ID($categoryname);$args = array ('fields' => 'all','include' => $categoryid);$tag_all = get_terms("category", $args);foreach($tag_all as $value):$cat_data = get_option('cat_'.intval($value->term_id));?><li><?php echo esc_html($value->name) ?><img src="<?php echo esc_html($cat_data['img']) ?>" width="110" height="110" /><?php echo wpautop($cat_data['extra_text']); ?></li><?php endforeach; ?></ul>修正した箇所は3~8行と16行目。3~8行で現在のカテゴリーのみ取得し、16行目で文章を表示してます。投稿のように改行や<p>タグを自動的に入れたいのでwpautop()を通してます。これでカテゴリーごとに任意の文章、画像を表示することが出来ます。ただし、予めレイアウトをHTMLで決めてしまうので画像の位置を変えることは出来ません。投稿の様に編集して表示したい場合は、カテゴリーごとに固定ページを用意し固定ページの中身を表示する必要があると思います。