サポート » テーマ » 各カテゴリにタグクラウド

  • 解決済 miracosta

    (@miracosta)


    お世話になります。

    各カテゴリの記事一覧ページに、そのカテゴリ内で使われているタグを
    タグクラウドの状態で表示したいのです。
    codexにtaxonomy=categoryというのがあったので、もしやと思って
    archive.phpのカテゴリパートに記述してみたのですが、(テーマはデフォルトのテーマです。)
    こちらはカテゴリ名がタグクラウドになるオプションだったようでした^^;

    お分かりになる方がいらしたら、どなたか教えていただけませんでしょうか。
    どうぞ宜しくお願い致します。

3件の返信を表示中 - 1 - 3件目 (全3件中)
  • functions.php:

    function my_category_tag_cloud($args) {
      $defaults = array(
        'smallest' => 8, 'largest' => 22, 'unit' => 'pt', 'number' => 45,
        'format' => 'flat', 'separator' => "\n", 'orderby' => 'name', 'order' => 'ASC',
        'exclude' => '', 'include' => '', 'link' => 'view', 'taxonomy' => 'post_tag', 'echo' => true
      );
      $args = wp_parse_args( $args, $defaults );
    
      global $wpdb;
      $query = "
        SELECT DISTINCT terms2.term_id as term_id, terms2.name as name, t2.count as count
        FROM
          $wpdb->posts as p1
            LEFT JOIN $wpdb->term_relationships as r1 ON p1.ID = r1.object_ID
            LEFT JOIN $wpdb->term_taxonomy as t1 ON r1.term_taxonomy_id = t1.term_taxonomy_id
            LEFT JOIN $wpdb->terms as terms1 ON t1.term_id = terms1.term_id,
          $wpdb->posts as p2
            LEFT JOIN $wpdb->term_relationships as r2 ON p2.ID = r2.object_ID
            LEFT JOIN $wpdb->term_taxonomy as t2 ON r2.term_taxonomy_id = t2.term_taxonomy_id
            LEFT JOIN $wpdb->terms as terms2 ON t2.term_id = terms2.term_id
          WHERE
            t1.taxonomy = 'category' AND p1.post_status = 'publish' AND terms1.term_id = " . $args['cat'] . " AND
            t2.taxonomy = 'post_tag' AND p2.post_status = 'publish'
            AND p1.ID = p2.ID
      ";
      $tags = $wpdb->get_results($query);
      foreach ( $tags as $key => $tag ) {
        if ( 'edit' == $args['link'] )
          $link = get_edit_tag_link( $tag->term_id, $args['taxonomy'] );
        else
          $link = get_term_link( intval($tag->term_id), $args['taxonomy'] );
        if ( is_wp_error( $link ) )
          return false;
    
        $tags[ $key ]->link = $link;
        $tags[ $key ]->id = $tag->term_id;
      }
    
      $return = wp_generate_tag_cloud( $tags, $args );
      $return = apply_filters( 'wp_tag_cloud', $return, $args );
    
      if ( 'array' == $args['format'] || empty($args['echo']) )
        return $return;
    
      echo $return;
    }

    表示したいところで:
    my_category_tag_cloud('cat=123'); // カテゴリーIDを指定

    トピック投稿者 miracosta

    (@miracosta)

    kzさま
    とても長いコードで恐縮しております。
    カテゴリーIDを自動で取得するために、こちらのサイト(ttp://blog.magical-remix.net/igalog/archives/99)を真似て、数行追加致しました。

    foreach((get_the_category()) as $cat) {
    	$cat_id = $cat->cat_ID ;
    	break ;
    	}
    $query = 'cat=' . $cat_id;
    my_category_tag_cloud($query);

    思い通りの動きをさせることが出来て嬉しいです。
    どうもありがとうございました!

    miracostaさん

    その、Kzさんのコ-ドに追記されたものを、表示したいところへ呼び出すにはどう記述すればいいのでしょうか?初心者ゆえ初歩的な質問、ご寛恕ください。

    現在、ウィジェットに「カテゴリ-」を設置していまして、ウィジェットスペ-スには作ったカテゴリ-が並んでいます。
    ブログ閲覧者の方がAというカテゴリ-を選んだ時に、Aカテゴリ-の記事がたくさん羅列されるのですが、その画面上部に、Aカテゴリ-専用のタグクラウドを表示したいのです。もちろんA以外のBやC、Dのカテゴリ-も同様に、それぞれのカテゴリ-専用のタグクラウドが欲しいと思っており、なんとかしたいと思っていたところ、KZさん、miracostaさんの書き込みを発見いたしました。なにとぞご教授いただきたく、よろしくお願いいたします。

3件の返信を表示中 - 1 - 3件目 (全3件中)
  • トピック「各カテゴリにタグクラウド」には新たに返信することはできません。