0%

Programmingプログラミングナレッジ

Posted:2018.07.12

WordPressのコメントに含まれるトラックバック・ピンバックを出力する

最近ではあまり見かけなくなりましたが、今回はトラックバックやピンバックを出力・表示させてコメントに対応させる機能を実装していきます。通常のサイトではあまり重要度は高くないかもしれませんが、WordPressのテーマ作成ではほぼ必須になっているのではないでしょうか。

 

トラックバック・ピンバックとは

トラックバックは簡単に説明すると、ブログ記事の相互リンクのようなものです。ある記事を参照した記事を作成した時に参照元のURLをトラックバックとして送信しておくことで、作成した記事のURLが自動で参照元記事に表示されるようになります。

 

つまり、記事間の相互リンクが自動で出来るようになります。ただしこれを悪用することでスパムリンクにもなりますので注意が必要です。

 

ピンバックも似たような仕組みですが、こちらは参照した記事内に含まれるリンクが自動的に参照元へ表示されるようになります。つまり相互リンクされたことを通知してくれるような機能になります。

 

トラックバックやピンバックを活用することで参照元からの流入につながりアクセスアップが期待できますので、ブログ運営者にとっては有効な機能になります。

 

内容を表示するリストをcomments.phpにコードを追記

まずはトラックバックを表示させるリスト部分を作成します。過去記事「WordPressのコメントリストとコメントフォームを実装してカスタマイズする」で紹介している「comments.php」内に下記のトラックバックのリスト出力コードを追記します。表示させる場所はコメントリストの前後で自由ですが、if (have_comments())の条件内で実行するようにします。

<?php if (have_comments()) :?>
<?php
  $commentCnt = get_comments(
    array(
      'status' => 'approve',
      'post_id'=> get_the_ID(),
      'type'=> 'comment',
      'count' => true
    )
  );
?>
………
(コメントリストを表示)
………
<!-- trackback-list start -->
<?php if (get_comments_number()-$commentCnt > 0) { ?>
<div class="o-post-trackbacks-box">
  <h3 class="o-trackbacks-count o-heading-aside"><?php echo get_comments_number()-$commentCnt; ?>件のトラックバック</h3>
  <ul class="o-trackback-list">
    <?php wp_list_comments('type=pings&callback=mytheme_pings'); ?>
  </ul>
</div>
<?php } ?>
<!-- trackback-list end -->
<?php endif; ?>

 

トラックバックはコメントの一部になりますので、get_comments()でコメント情報を取得し、純粋なコメントの数のみを抽出して、その数を変数に持たせておくことでトラックバック数を算出することがポイントです。またコメントリストの表示を行う、wp_list_comments()では引数に後述のトラックバックリストを出力するコールバック関数を指定する形になります。

 

コールバック関数をfunctions.phpに追記

リストを表示させる側の実装が完了すると、次はリストを出力していく部分を作成していきます。コメントリストの時と同じく、トラックバック・ピンバック用のコールバック関数を「functions.php」に追記します。

function mytheme_pings($comment, $args, $depth) {
  $GLOBALS['comment'] = $comment; ?>
  <li <?php comment_class(); ?> id="li-comment-<?php comment_ID() ?>">
    <div id="comment-<?php comment_ID(); ?>" class="comment-body">
    <?php printf(__('%s'), get_comment_author_link()) ?>
      <div class="comment-meta">
       <?php printf(__('%1$s'), get_comment_date()) ?><?php edit_comment_link(__('(Edit)'),'','') ?>
      </div>
      <?php comment_text() ?>
    </div>
  <?php
}

 

これで、トラックバックやピンバックの内容がリストで表示されるようになります。最近ではどちらかというとSNSなどのシェアが主流になり、スパム目的でトラックバックが悪用されるケースが増えてきていることもあり、あまり見かけなくなってきましたが、要件として求められる場合はあるかと思います。そんな時には参考になるのではないでしょうか。

 

(参考)
WordPressのコメントとトラックバックを分けてカスタマイズ
[WordPress] コメント数だけ・ピンバック数だけをそれぞれ取得する方法

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

こんな記事も読まれています

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】