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

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

ただいまの
回答率

90.75%

  • PHP

    19154questions

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

  • WordPress

    6636questions

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

wordpressでサイドバーに人気記事のランキングをプラグインを使わずに表示させたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 276

dadada-dadada

score 18

前提・実現したいこと

下記のようなコードを子テーマのfunction.phpに追記して、自分でカスタマイズした人気記事のランキングを表示させるウィジェットを追加したいのですが、この記述のファイルをアップしたらサイト上で何も表示されなくなってしまいました。。。

こちらの記事を参考に試してみたのですが、どこの記述が原因で表示されないのかがわからなくて困っています。どなたかご教授お願い致します。
https://plusers.net/wordpress_popular_posts

使用している親テーマ:LION MEDIA
http://lionmedia.fit-jp.com/

/* 人気記事一覧ウィジェット */
class Popular_Posts extends WP_Widget {
/*コンストラクタ*/
function __construct() {
parent::__construct(
'popular_posts',
'人気記事 - myCustom',
array( 'description' => 'PV数の多い順で記事を表示 - myCustom' )
);
}
/*ウィジェット追加画面でのカスタマイズ欄の追加*/
function form($instance) {
?>
<p>
<label for="<?php echo $this->get_field_id('title'); ?>"><?php _e('タイトル:'); ?></label>
<input type="text" class="widefat" id="<?php echo $this->get_field_id('title'); ?>"
name="<?php echo $this->get_field_name('title'); ?>"
value="<?php echo esc_attr( $instance['title'] ); ?>">
</p>
<p>
<label for="<?php echo $this->get_field_id('number'); ?>"><?php _e('記事表示件数:'); ?></label>
<input type="text" id="<?php echo $this->get_field_id('limit'); ?>"
name="<?php echo $this->get_field_name('number'); ?>"
value="<?php echo esc_attr( $instance['number'] ); ?>" size="3">
</p>
<?php
}
/*カスタマイズ欄の入力内容が変更された場合の処理*/
function update($new_instance, $old_instance) {
$instance = $old_instance;
$instance['title'] = strip_tags($new_instance['title']);
$instance['number'] = is_numeric($new_instance['number']) ? $new_instance['number'] : 5;
return $instance;
}
/*ウィジェットのに出力される要素の設定*/
function widget($args, $instance) {
extract($args);
echo $before_widget;
if(!empty($instance['title'])) {
$title = apply_filters('widget_title', $instance['title'] );
}
if ($title) {
echo $before_title . $title . $after_title;
} else {
echo '<h4>人気記事</h4>';
}
$number = !empty($instance['number']) ? $instance['number'] : get_option('number');
?>
<!--ここにウィジェットとして呼び出したい要素を記述-->
<aside class="sidekiji">
    <ul>
    <?php get_the_ID();//記事のPV情報を取得する
    $args = array('meta_key'=> 'post_views_count',//投稿数をカウントするカスタムフィールド名
    'orderby' => 'meta_value_num',
    'order' => 'DESC',
    'posts_per_page' => $number
    );
    $my_query = new WP_Query( $args );?>
    <?php while ( $my_query->have_posts() ) : $my_query->the_post(); $loopcounter++; ?>
    <li>
    <a href="<?php the_permalink(); ?>">
    <!--順位-->
    <span class="rank-count r-count<?php echo $loopcounter; ?>">
    <?php echo $loopcounter; ?>
    </span>
    <!--サムネイル画像の追加-->
    <?php if( has_post_thumbnail() ): ?>
    <?php the_post_thumbnail('thumbnail'); ?>
    <?php endif; ?>
    <div class="sidekiji-text">
    <?php the_title(); ?>
    <br>
    <!--タイトル-->
    <?php the_title(); ?>
    <!--カテゴリ-->
    <span class="cat-data">
    <?php if( has_category() ): ?>
    <?php $postcat=get_the_category(); echo $postcat[0]->name; ?>
    <?php endif; ?></span>
    </div>
    </a>
    </li>
    <?php endwhile; ?>
    <?php wp_reset_postdata(); ?>
    </ul>
    </aside>
<!-- / ここにウィジェットとして呼び出したい要素を記述-->
<?php echo $after_widget;
}
}
register_widget('Popular_Posts');
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • 退会済みユーザー

    2018/01/23 15:19

    複数のユーザーから「やってほしいことだけを記載した丸投げの質問」という意見がありました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

  • miz

    2018/01/23 16:10

    質問者様が行いたいのはLION MEDIAの人気記事一覧ウィジェットのソースコードを再利用しつつ、ウィジェットを使わずにランキングを表示したいということでよろしいですか。(質問文中に「「function.phpに~」という記事を何個も読みながら何回も試した」とあるので、親テーマの機能を使うことにこだわってないようにも見受けられたので確認です)

    キャンセル

  • dadada-dadada

    2018/01/23 16:17 編集

    親テーマのコードを利用したほうが子テーマのfunction.phpのコード量も増えず、今後メンテしやすいかなと思ったのですが、それがうまくいかず、新たにfunction.phpに記述する方法も試してみたのですが、そちらもうまくいかず・・・というのがこの質問をするに至った経緯です。言葉足らずで申し訳ございません。

    キャンセル

回答 1

checkベストアンサー

+2

LION MEDIAのコードを再利用するケースと参考にされたサイトのコードを利用するケースの両方を確認したので、記載します。

LION MEDIAのコードを再利用する場合

LION MEDIAの人気記事ランキングは投稿のメタ情報に閲覧数を記録する方式です。
そのため、この閲覧数を利用したい場合は以下のようなコードを記載することでランキングを表示できます。

$args = array(
    'meta_key'=> 'post_views_count',
    'orderby' => 'meta_value_num',
    'order' => 'DESC',
    'posts_per_page' => 3,
);
$my_query = new WP_Query( $args );

echo '<ol>';

while ( $my_query->have_posts() ) :
    $my_query->the_post();
    echo '<li><a href="' . get_the_permalink() .'">' . get_the_title() . '</a></li>';
endwhile;
wp_reset_postdata();

echo '</ol>';

参考にされたサイトのコードを利用する場合

https://plusers.net/wordpress_popular_posts

/* 人気記事一覧ウィジェット */
class Popular_Posts extends WP_Widget {
/*コンストラクタ*/
function __construct() {
parent::__construct(
(以下略)


こちらのページに掲載のウィジェットのソースコードをfunctions.phpに記述して利用した場合についても、ウィジェットとして正常に動作することが確認できました。

この記述のファイルをアップしたらサイト上で何も表示されなくなってしまいました。。。

とのことなので、PHPのなんらかのエラー(おそらく構文エラー)が発生して、500エラーになっているものと思われます。
発生しているエラー内容を確認して、質問文に追記していただけますか。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/01/24 12:10

    phpの閉じタグが重複しているのがエラーの原因でした....お教えいただいた親テーマのコードを利用する方法でアイキャッチや他のパーツもうまく表示されました!ありがとうございました。

    キャンセル

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

  • ただいまの回答率 90.75%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    19154questions

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

  • WordPress

    6636questions

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