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

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

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

RSS(Really Simple Syndication)はブログのエントリやニュースの見出し、標準のフォーマットの音声やビデオなどを発行するために使われるウェブフィードのフォーマットの集合体です。

PHP

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

0回答

732閲覧

RSSで取得した記事タイトルの高さを揃えたい

ync_pp

総合スコア11

RSS

RSS(Really Simple Syndication)はブログのエントリやニュースの見出し、標準のフォーマットの音声やビデオなどを発行するために使われるウェブフィードのフォーマットの集合体です。

PHP

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2021/10/28 02:54

編集2021/10/28 03:49

初歩的な質問で恐れ入りますが、アドバイスいただけますと幸いです。

#実現したいこと
外部のWordPressサイトからRSSで新着記事を取得してタイル状に配置し、
slickで横一列に並べてスライドするようにしています。

PHPを使ってRSSを取得し、取得した要素(タイトル)の高さをjQueryで自動的に揃えるようにしたいです。

#現在の状況
取得したタイトルのボックス(h2)の高さを「heightLine」というjQueryプラグインで揃えています。

ローカル環境では問題ないのですが、本番環境でタイトル部分のボックスの高さが思うように取得されません。
(例えば1行と2行のタイトルが混在したときに40pxの高さを確保して欲しいのに、16pxで取得・適用されてしまい文字が下にはみ出ます)

slickの実行前にheightLineが実行されてしまっているためかと思い、
slickのコールバックでheightLineを呼び出すようにしましたが、変わりませんでした。

そこで、RSSのタイトル(<h2><?php echo $news['title'];?></h2>)が書きだされる前にheightLineが適用されているのかなと思ったのですが、ではどうしたら良いのかというところで詰まっています。

RSS取得用のコードは直接トップページのphpファイルに書き込んでいます。
jQueryのScriptはbodyの閉じタグ前で記述しています。

  1. PHPでRSSを取得(タイトル文字列取得)
  2. HTML吐き出し(タイトル文字列が書き出される)
  3. slick読み込み後にheightLine実行

という順番で実行されると思っているのですが、間違っていますでしょうか。
ローカル環境では問題ないため、そもそも実行順ではなく別の原因なのでしょうか。

解決のヒントになるような検索のキーワードなどでも構いませんので、
お力をお借りできますと幸いです。

php

1<div class="slick-wp"> 2 <?php 3 // XMLファイルを文字列として取得 4 $feed = file_get_contents('https://hogehoge.com/feed/'); 5 // XMLの不正文字を空文字に変換 6 $invalid_characters = '/[^\x9\xa\x20-\xD7FF\xE000-\xFFFD]/'; 7 $feed = preg_replace($invalid_characters, '', $feed); 8 // 文字列をXMLとして解析しSimpleXMLElementに変換 9 $rss = simplexml_load_string($feed); 10 $news_list = array(); 11 $news_cnt = 0; 12 foreach ($rss->channel->item as $item) { 13 $news_list[] = array( 14 'title' => $item->title, 15 'date' => date("Y/m/d", strtotime($item->pubDate)), 16 'link' => $item->link, 17 'img' => $item->image->url 18 ); 19 $news_cnt++; 20 if ($news_cnt==8) { break; } 21 } 22 ?> 23 <?php foreach ($news_list as $news):?> 24 <div class="slick-wp-content heightLine"> 25 <a href="<?php echo $news['link'];?>" target="_blank"> 26 <h2><?php echo $news['title'];?></h2> 27 <?php if ($news['img']): ?> 28 <img src="<?php echo $news['img']?>" alt="<?php echo $news['title'];?>" width="280" height="210" loading="lazy"> 29 <?php else:?> 30 <img src="<?php echo get_template_directory_uri(); ?>/images/top/wp-noimage.png" alt="noimage"> 31 <?php endif;?> 32 <p class="date"><?php echo $news['date'];?></p> 33 </a> 34 </div> 35 <?php endforeach;?> 36</div>

jQuery

1$(function(){ 2 $('.slick-wp').on('init', function() { 3 $('.slick-wp-content.heightLine').find('h2').heightLine(); 4 }); 5 $('.slick-wp').slick({ 6     // slickのオプション 7 }); 8});

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問