初歩的な質問で恐れ入りますが、アドバイスいただけますと幸いです。
#実現したいこと
外部の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の閉じタグ前で記述しています。
- PHPでRSSを取得(タイトル文字列取得)
- HTML吐き出し(タイトル文字列が書き出される)
- 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});
あなたの回答
tips
プレビュー