1

写真を変更するために、自分のページに前|次のリンクを設定したいと考えています。

関数を使用して関連要素を取得します。ただし、関数に必要な追加コードとその配置場所がわかりません。また、html セクションにあるもの。

「foreach」の次/前の多くのページを見てきましたが、それらに関連しているようには見えません。

コード:

function image_data($image_album_id) {
    $image_album__id = (int)$image_album_id;
    $args = func_get_args();
    unset($args[0]);
    $fields = '`'.implode('`, `', $args).'`';

    $query = mysql_query("SELECT $fields FROM `album_images`
    WHERE `image_album_id`=$image_album_id AND `member_id`= '1'");
    $ query_result = mysql_fetch_assoc($query);

    foreach ($args as $field) {
        $args[$field] = $query_result[$field];

    }
    return $args;
    }

HTML ページ:

<a href="">Last</a>|
<a href="">Next</a>
</div>


<?php
 $image_album_id =$_GET['image_album_id'];
 $image_data = image_data($image_album_id, 'album_id', 'albumname', 'ext', 'timestamp');

 echo '';
 ?>

<td class="smallfont albumthumb2" align="center" valign="middle"  >
<a href="album_viewT.php?=<?php echo 'images/albums/thumbs/'. $image_data['album_id'].        '/'. $image_album_id. '.' .$image_data['ext']; ?> "></a>
<img alt="" class="album_cover" src="<?php echo 'images/albums/thumbs/'.       $image_data['album_id']. '/'. $image_album_id. '.' .$image_data['ext'];?> " height="175px"      width="175px">
</td>

どうもありがとう。私が理にかなっていることを願っています。


迅速な対応に感謝します。

見て消化することがたくさんあるので、うまくいくかどうか見てみようと思いました。

悲しいかな。

解析エラーがあります: 構文エラー、行に予期しない '<' があります

$prev_link = 前;

そのセクション内で気付いた唯一のことは、'title="$prev_name"}' の後の余分な中括弧です。

'title="$next_name"}' についても同じことがわかります


あなたの特定の質問を参照して。

前のページのリンクをクリックすると、album_viewT ページに移動します。これには小さなサムネイルが含まれています。例として、リンクは localhost/Testing/album_view.php?artist_id=4&image_album_id=4 です。

「日付の順序は image_album_data による」を完全に理解しているかどうかわかりません

はい、データベースには約 3,000 行あります。

また、album_id が artist_id に置き換えられたことにも言及する必要があります。


href を「album_view.php/id/...」に変更する必要がありますか?

4

1 に答える 1

0

あなたの質問にはいくつかのデータがありません。つまり、このコードを生成するアクセスしているページ (つまり URL) と、データがどのようにソートされているかです。たとえば、album_viewT.php?スクリプトを使用してより多くの情報を提供している可能性があることがわかりますが、それは必ずしも作成した HTML を表示するものではありません。

したがって、このすべての後、いくつかの仮定を立て、うまくいけば、それが解決策に到達するための正しいガイダンスを提供します.

  • あなたの訪問ページはhttp://mysite.com/albums/id/25であると仮定しています
  • また、データの順序は image_album_id 順であると想定しています。
  • 最後に、データベースにデータがあり、現在のイメージのテンプレートに返されたデータがあるかどうかを確認する必要はないと仮定しています。それを自分で整理する必要があります。

最初にデータベースからデータを取得する必要があります。

function image_data($image_album_id) 
{
    $results         = array(
                           'previous' => FALSE, 
                           'current'  => FALSE, 
                           'next'     => FALSE,
                       );
    $image_album__id = (int)$image_album_id;
    $args            = func_get_args();
    unset($args[0]);
    $fields = '`'.implode('`, `', $args).'`';

    // Current record 
    $results['current'] = get_data(
                              $fields, 
                              "AND image_album_id = {$image_album_id}"
                          );

    // Previous - no need to run this if we don't have a current
    if ($results['current'])
    {
        // Current record 
        $results['previous'] = get_data(
                                   $fields, 
                                   "AND image_album_id < {$image_album_id} " . 
                                   "LIMIT 1"
                               );
    }

    // Next - no need to run this if we don't have a current
    if ($results['current'])
    {
        // Current record 
        $results['next'] = get_data(
                               $fields, 
                               "AND image_album_id > {$image_album_id} " . 
                               "LIMIT 1"
                           );
    }

    // If all went well the $results array will contain the data 
    // for the 3 records. If we are at the beginning or the end, 
    // the previous and/or next will be FALSE
    return $results;
}

function get_data($fields, $where = '')
{
    $return = FALSE;

    // Template
    $template = "SELECT %s "
              . "FROM album_images "
              . "WHERE member_id = 1 %s";

    // Current record 
    $sql          = sprintf($template, $fields, $where);
    $query        = mysql_query($sql);
    $query_result = mysql_fetch_assoc($query);

    // If data has been found
    if ($query_result)
    {
        $return = $query_result;
    }

    return $return;
}

HTML ページの場合:

<?php
    $image_album_id = $_GET['image_album_id'];
    $image_data     = image_data(
                          $image_album_id, 
                          'album_id', 'albumname', 'ext', 'timestamp'
                      );

    $prev_link = '';
    $next_link = '';

    if ($image_data['previous'])
    {
        $prev_id   = $image_data['previous']['album_id'];
        $prev_name = $image_data['previous']['albumname'];
        $prev_link = <a href="/albums/id/{$prev_id}" title="$prev_name"}>Previous</a>";
    }

    if ($image_data['next'])
    {
        $next_id   = $image_data['next']['album_id'];
        $next_name = $image_data['next']['albumname'];
        $next_link = <a href="/albums/id/{$next_id}" title="$next_name"}>Next</a>";
    }

    $curr_id   = $image_data['current']['album_id'];
    $curr_ext  = $image_data['current']['ext'];
?>

<?php echo $prev_link; ?>|<?php echo $next_link; ?>
</div>

<td class="smallfont albumthumb2" align="center" valign="middle">
    <a href="album_viewT.php?images/albums/thumbs/
        <?php echo "{$curr_id}/{$image_album_id}.{$curr_ext}; ?>
        <img alt="" class="album_cover" 
             src="images/albums/thumbs/
                 <?php echo "{$curr_id}/{$image_album_id}.{$curr_ext}"; ?>
             height="175px"
             width="175px" />
    </a>
</td>

注:わかりやすくするために、HTML ファイル内のimgとタグの行を分割しました。a

于 2012-09-11T03:54:40.120 に答える