質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CMS

CMS(Content Management System)は複数のユーザーでコンテンツを編集することが可能なWebサイトの管理/構築用のプラットフォームを指します。また、会社単位で運用管理するものはECMと呼びます。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

Q&A

0回答

840閲覧

タクソノミー共用で、複数カスタム投稿ごとの記事数が合算される問題を解決したい

iambeginnerr

総合スコア12

CMS

CMS(Content Management System)は複数のユーザーでコンテンツを編集することが可能なWebサイトの管理/構築用のプラットフォームを指します。また、会社単位で運用管理するものはECMと呼びます。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

0グッド

1クリップ

投稿2021/04/16 04:48

前提・実現したいこと

2種類のカスタム投稿で一つのタクソノミーを共用しています。
カスタム投稿ごとにターム一覧と記事数を取得したいのですが、2種類のカスタム投稿の合算記事数が出力されてしまいます。

こちらのページを参考に試行錯誤してみましたが、記事数は合算のままです。

どの部分がまずいのでしょうか。
phpは初心者です。
知恵をお貸しください!!

ー設定詳細ー
■カスタム投稿その1
カスタム投稿名:shop
タクソノミー:area_cat(共用)

■カスタム投稿その2
カスタム投稿名:blog
タクソノミー:area_cat(共用)

ー現在の表示ー
shop tokyo(area_catのターム) 10件の記事あり
blog tokyo(area_catのターム) 5件の記事あり

area_catのtokyoのタームの数を取得すると15という数字になってしまう

ー理想の表示ー
shop tokyo(10)
blog tokyo(5)
と、表示したい

該当のソースコード

functions.php

//共通タクソノミー使用でもトータルカウントされないようにする function df_terms_clauses($clauses, $taxonomy, $args) { if (!empty($args['post_type'])) { global $wpdb; $post_types = array(); foreach($args['post_type'] as $cpt) { $post_types[] = "'".$cpt."'"; } if(!empty($post_types)) { $clauses['fields'] = 'DISTINCT '.str_replace('tt.*', 'tt.term_taxonomy_id, tt.term_id, tt.taxonomy, tt.description, tt.parent', $clauses['fields']).', COUNT(t.term_id) AS count'; $clauses['join'] .= ' INNER JOIN '.$wpdb->term_relationships.' AS r ON r.term_taxonomy_id = tt.term_taxonomy_id INNER JOIN '.$wpdb->posts.' AS p ON p.ID = r.object_id'; $clauses['where'] .= ' AND p.post_type IN ('.implode(',', $post_types).')'; $clauses['orderby'] = 'GROUP BY t.term_id '.$clauses['orderby']; } } return $clauses; } add_filter('terms_clauses', 'df_terms_clauses', 10, 3);

index.php

<div> <p>関東</p> <ul class="area"> <?php $post_type = 'shop'; $taxonomy = 'area_cat'; $args = array( 'parent' => 0, 'slug' => array('tokyo','kanagawa','saitama','chiba','tochigi','ibaraki','gunma'), 'pad_counts' => false, 'hide_empty' => false ); $terms = get_terms( $taxonomy , $args ); if ( count( $terms ) != 0 ) { foreach ( $terms as $term ) { $term = sanitize_term( $term, $taxonomy ); $term_link = get_term_link( $term, $taxonomy ); if ( is_wp_error( $term_link ) ) { continue; } $slug = $term->slug; ?> <?php echo '<li><a href="' . esc_url( $term_link ) . '" >' . $term->name .'<span class="count">(' .$term->count. ')</span></a></li>'; $posts = get_posts( array( 'post_type' => $post_type, 'taxonomy' => $taxonomy, 'term' => $slug, 'meta_key' => 'order_num' )); foreach($posts as $post){ ?> <?php } wp_reset_query(); ?> <?php } } ?> </ul> </div>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問