0

whileループ内の最初の2つのif/elseifステートメントは、ニュースアイテムの画像が存在するかどうかを確認し、存在しない場合はスキップします。カウンターは、これが上部の最初の3つのアイテムに対してのみ行われることを確認します。現在、これはエラーなしで正常に機能します。

上位2つのif/elseifステートメントで画像付きの投稿のみを使用するようにしたい($ row-> imagelibid)-7日前に画像付きのニュース記事がある可能性があるため、上部にそれを使用します-強制されます画像付きのニュース記事を見つけて使用します。これは、これらの「選択された」ストーリーの日付の順序が間違っていることを意味しますが、それは問題ありません。

それが理にかなっていることを願っています...そして私が感謝するどんな助けでも。

$site_url = "http://www_#_com";
    $full_site_url = $site_url . "/" . $news_prefix . "news/" . $row->id;
    $news_prefix = "#";
    $adFrequency = 5;
    $ad = 0;
    $i = 0;

    $result = mysql_query( "SELECT news.*, regions.name AS territory FROM news JOIN country ON news.country = country.iso JOIN regions ON regions.id = country.region WHERE news.mobile_app != 0 AND news.hidden = 0 AND news.beef = 1 ORDER BY news.datein DESC LIMIT 20", $db );

    while ( ( $row = mysql_fetch_object( $result ) ) !== false ) {

    $imageid = intval( $row->imagelibid );
    $image_result = mysql_query( "SELECT * FROM imagelib WHERE id = {$imageid}", $db );
    $image_row = mysql_fetch_object( $image_result );
    $image_url = "http://www.#.com/slir/w280/imagelib/" . $image_row->id . "_" . $image_row->filename;

    if ($i <= 0 && !empty($row->imagelibid)) {

    echo '<div class="one-news-featured-article clearfix">';
    echo '<div class="grid_12">';
    echo '<div class="large-featured-image-container"><img src="'.$image_url.'">';  
    echo '<div><h2><a href="item-news.php?id='.$row->id.'">'.$row->title.'</a></h2></div>';
    echo '</div>';
    echo '</div>';
    echo '</div>';

    }

    elseif ($i <= 2 && !empty($row->imagelibid)) {

    echo '<div class="one-news-featured-article clearfix">';
    echo '<div class="grid_6">';    
    echo '<div class="small-featured-image-container"><img src="'.$image_url.'">';  
    echo '<div><h2><a href="item-news.php?id='.$row->id.'">'.$row->title.'</a></h2></div>';
    echo '</div>';
    echo '</div>';
    echo '</div>';

    }

    else {

    // Places ad based of predefined variable frequency
    if ($ad == $adFrequency){

     echo'<div class="one-advertisement-article clearfix">';
     echo'<div class="grid_9 suffix_2"><img src="http://placehold.it/263x75/000000/ffffff"></div>';
     echo'<div class="grid_1"><a class="navigate-right-icon ss-icon" href="#">navigateright</a></div>';
     echo'</div>';

     $ad = 0;
    }

    echo '<div class="one-news-article clearfix">';
    if( $row->imagelibid )
            {
                echo '<div class="grid_4"><a href="#"><img src="'.$image_url.'"></a></div>';        
            }
    else {
                echo '<div class="grid_4"><div class="news-placeholder"><span class="ss-icon">ellipsischat</span></div></div>';
        }

    echo '<div class="grid_7">';
    echo '<h2><a href="item-news.php?id='.$row->id.'">'.$row->title.'</a></h2>';

    $published_date = date('D, d M Y', strtotime($row->datein));
    echo '<p class="published-date">'.$published_date.'</p>';

    echo '<p class="news-snippet">'.$row->snippet.'</p>';
    echo '</div>';
    echo '<div class="grid_1">';
    echo '<div class="news-item-vertical-sep">&nbsp;</div>';
    echo '<p></p>';
    echo '</div>';
    echo '</div>';

    $ad++;

    }

    $i += 1;

    }

PS mysql_は非推奨の関数であることを私は知っていますが、これが今のところ見落とされている可能性がある場合は、それは良いことです。

4

1 に答える 1

0

すべての結果をループするだけで、画像が見つかった場合は配列に保存し、たとえば $newsWithImage に保存し、見つからない場合は別の配列 $newsWithoutImage に保存します。それが完了したら、最初の配列をループして結果をエコーアウトしてから、他の配列を取得します。

while ( ( $row = mysql_fetch_object( $result ) ) !== false )
{
   if($row->imagelibid)
      $newsWithImage[] = $row;
   else
      $newsWihtoutImage[] = $row;
}

foreach($newsWithImage as $news)
{
  // do your html output with the results 
}

foreach($newsWithoutImage as $news)
{
  // do your html output with results
}
于 2012-12-13T11:10:36.670 に答える