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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Webサイト

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

WordPress

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

PHP

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

Q&A

解決済

1回答

945閲覧

phpを使って、フロントページにカスタム投稿の新着記事を表示させたい

pigashi

総合スコア8

Webサイト

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

WordPress

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

PHP

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

0グッド

0クリップ

投稿2019/12/26 03:10

編集2019/12/26 03:19

どんなクエリで参考記事を探したらいいのかも思いつかなかったため、質問させて頂くに至りました。

なかなかとんちんかんな質問になってしまっておりますが、「これを調べてから出直してこーい!」的な情報でも構いませんのでご教授いただけますと幸いです。

前提・実現したいこと

【やりたいこと:フロントページにカスタム投稿の新着記事を表示させたい】
バージョン:WordPress 5.3.2 (Luxeritas Child Theme テーマ)
表示させたいpost_typeはcolumnです。

固定ページで作ったフロントページに、カスタム投稿の新着記事を表示させるべく、使用中のテーマ、ルクセリタスのショートコード機能を使用し、表示させようとしています。
(が、当方phpど素人すぎて詰んでしまいました...。)
次に私が試した内容になります。

試したこと

①Luxeritas のショートコード機能を使ってphpでカスタム投稿の新着記事を表示させようとする
ショートコードを
[new_list count=5 post_type="column"]

にして、下記コードを記述したところ、登録できず....

<?php if (!empty($posts)): ?> <ul class="blog-card-desc"> <?php foreach ($posts as $post):setup_postdata($post); ?> <li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li> <?php endforeach; ?> <?php wp_reset_postdata(); ?> </ul> <?php endif; ?>

ショートコードがよくないのかなと思い、
[new_posts_type="column" new_list count=5]
に変更して再度登録しようとするもエラーで不可。

②ショートコード機能を使わずに、function.phpに直接書き込んでどうにかしようとする
①で登録しようとしていた記述をそっくりそのままfunction.phpに書き込んでみました。

<?php if (!empty($posts)): ?> <ul class="blog-card-desc"> <?php foreach ($posts as $post):setup_postdata($post); ?> <li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li> <?php endforeach; ?> <?php wp_reset_postdata(); ?> </ul> <?php endif; ?>

普通にダメでした...

参考にした記事

▼カスタム投稿タイプの新着一覧を表示する方法【WordPress】
https://www.web-myoko.net/blog/wordpress/wordpress-custom-post-type-how-to-display-new-list/#s03

▼Luxeritas のショートコード機能を使って php でカテゴリの新着記事を表示させる
https://yaruzou.net/luxeritas-shortcode-php
※私が実現したかったのは、ショートコード機能を使ってphpでカスタム投稿の新着記事を表示させること...なのですが、記述がcatidだったので、どの部分をどのように、カスタム投稿用に変更すればいいのかさっぱり.....(白目)

補足情報

・カスタム投稿はCPT UIというプラグインを使用して設定しました
・作業ファイルは子テーマのものを使用しています。

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

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

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

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

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

guest

回答1

0

ベストアンサー

foreachのあたりは削除してこんな感じにされるとどうでしょうか?

php

1$newPosts = new WP_Query( 2'post_type' => 'カスタム投稿名', 3'posts_per_page' => 5, 4'post_status' => 'publish' 5); 6 7if($newPosts->have_posts():while($newPosts->have_posts()):$newPost->the_post(); 8 // 適当に 9 the_title(); 10endwhile;endif; 11wp_reset_postdata();

投稿2019/12/26 03:50

madone99

総合スコア1855

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

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

pigashi

2019/12/26 06:18

回答頂きましてありがとうございます!! 無事表示できました...!頂いたテンプレを参考にいろいろとカスタマイズできました(´;ω;`) 大変助かりました...今後とも引き続き何卒宜しくお願い致しますm(__)m
madone99

2019/12/26 06:24

解決できたようで何よりです。 ちなみにですが、get_posts()は非推奨になっていますので その箇所は利用されない方が良いと思われます。
pigashi

2019/12/26 07:18

そうだったのですね... 今までget_postsとWP_Queryの違いが正直よくわかっていなかったため、学べる貴重な機会となりました! ショートコードを作成する際にはWP_Queryで書くよう気を付けたいと思いますm(__)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問