ページングの問題: ページング クエリを実行できません
コードを読みたくない場合は、私の説明を読んでから解決策を送信してください。これは、Baidu に似た検索ページです。検索ボックスがあります
以下はクエリ結果を表示します。 たとえば、PHP を検索し、テーブルの num フィールドの下にある PHP の内容を検索すると、クエリの結果がすべてページネーションで表示されます。
最初のページと 2 番目のページです... ここでの問題は、クエリ結果がユーザーに基づいて、送信されるたびにデータベースのクエリに $_POST['num'] が使用されることです。
5 個の場合。各ページに 1 つのデータが表示され、3 ページのデータがクエリされるようになりました。各クエリではデータとページング情報を表示できますが、たとえば、2 番目のページをクリックすると、エラーが報告されます。 2 番目のページをクリックすると、送信された $_POST['num'] データがないため、エラーが報告されるのは 1 つのみです。最初のページのデータをクエリできるのですが、2 番目のページをクリックするとエラーが報告されます。しかし、ユーザーが 2 番目のページをクリックしたときにそれを修正する方法がわかりません。以前にクエリしたデータが消えないことを願っています。これについてはどうすればよいですか?誰もがこれを理解できるかどうかはわかりません
<div id="show"> <?php header('content-type:text/html;charset=utf-8;'); include 'function.php'; if (isset($_POST['num'])||isset($_GET['page'])) { $pdo=new PDO("mysql:host=localhost;dbname=t1","root",""); session_start(); $_SESSION['num']=$_POST['num']; $stmt3=$pdo->prepare("select * from table1 where num=?"); $stmt3->execute(array($_POST['num'])); $res3=$stmt3->fetchall(); $rows=count($res3); $pagesize=5; if($rows==0){ $pagenum=1; }else{ $pagenum=ceil($rows/$pagesize); } if(isset($_GET['page'])){ $page=$_GET['page']; if(empty($page)||$page<0||!is_numeric($page)) { $page=1; }else{ $page=intval($page); } }else{ $page=1; } if($page>$pagenum){ $page=$pagenum; } $startnum = ($page - 1)*$pagesize; $display_page=5; $query = "SELECT * FROM qq where num=? LIMIT $startnum,$pagesize"; $stmt=$pdo->prepare("$query"); //$stmt=$pdo->prepare("select * from table1 where num=?"); $stmt->execute(array($_POST['num'])); $res=$stmt->fetchall(PDO::FETCH_ASSOC); $v = current($res); if($res){ foreach($res as $v){ //echo '<h3><span>'.$v['num'].'</span></h3>' ; echo '<h4>'.$v['name'].'</h4>'; } }else{ echo "无数据"; } } ?> </div> <div id="page"> <?php if(isset($_POST['num'])||isset($_GET['page'])){ fenye(); } ?> </div>
ディスカッション (解決策) への返信
あなたの番号は郵送で送信されました。 2 ページ目、当然これ以上 num はありません
なぜなら、最初のページと 2 ページ目をクリックすると、POST メソッドの代わりに GET メソッドが使用されるからです。 sso赤い部分に問題があります= $ pdo-&gt; prepare( "select * from table1 where num =?"); );
その後、fenye メソッドは num と page を追加する必要があります
pagination に渡される URL には、次の 2 つのパラメータを追加する必要があります:?page=xxx&num=xxx
次のように変更してみてください
<div id="show"> <?php header('content-type:text/html;charset=utf-8;'); include 'function.php'; $num = isset($_REQUEST['num'])? $_REQUEST['num'] : 0; $page = isset($_REQUEST['page'])? $_REQUEST['page'] : 1; $pdo=new PDO("mysql:host=localhost;dbname=t1","root",""); session_start(); $_SESSION['num']=$num; $stmt3=$pdo->prepare("select * from table1 where num=?"); $stmt3->execute(array($num)); $res3=$stmt3->fetchall(); $rows=count($res3); $pagesize=5; if($rows==0){ $pagenum=1; }else{ $pagenum=ceil($rows/$pagesize); } if($page){ if(empty($page)||$page<0||!is_numeric($page)) { $page=1; }else{ $page=intval($page); } }else{ $page=1; } if($page>$pagenum){ $page=$pagenum; } $startnum = ($page - 1)*$pagesize; $display_page=5; $query = "SELECT * FROM qq where num=? LIMIT $startnum,$pagesize"; $stmt=$pdo->prepare("$query"); //$stmt=$pdo->prepare("select * from table1 where num=?"); $stmt->execute($num); $res=$stmt->fetchall(PDO::FETCH_ASSOC); $v = current($res); if($res){ foreach($res as $v){ //echo '<h3><span>'.$v['num'].'</span></h3>' ; echo '<h4>'.$v['name'].'</h4>'; } }else{ echo "无数据"; } ?> </div> <div id="page"> <?php if($num || $page){ fenye($num, $page); } ?> </div>
次のようになりますBaidu、Baidu の次のページのリンクを見てください。検索語はすべてアドレスパラメータに含まれていますが、最初のページをクリックしてもエラーが報告されないだけです。または 2 ページ目では、メソッドは POST メソッドではなく GET メソッドで渡されます。 sso赤い部分に問題があります= $ pdo-&gt; prepare( "select * from table1 where num =?"); );
次に、fenye メソッドで num と page を追加する必要があります。
pagination に渡される URL には、次の 2 つのパラメーターを追加する必要があります。この問題を解決します?
あなたの番号は郵送で送信されました。2 ページ目以降は投稿がありません。したがって、当然、番号はもうありません
这个那个分页函数的代码
function fenye(){
global $page,$pagenum,$shoupage,$pageoffset;
echo "
echo "
- ";
- '.$page.'/'.$pagenum.'页| ';
- 首页| ';
- 上一页| ';
- 首页| ';
- 上一页| ';
- |下一页| ';
- 尾页| ';
- |下一页| ';
- 尾页| ';
echo '
if($page==1){
echo '
echo '
}else{
echo '
echo '
}
$shoupage=5;
$pageoffset=($shoupage-1)/2;
$start=1;
$end=$pagenum;
if($pagenum>$shoupage){
if($page>$pageoffset){
$start=$page-$pageoffset;
$end=$pagenum>$page+$pageoffset?$page+$pageoffset:$pagenum;
}else{
$start=1;
$end=$pagenum>$shoupage?$shoupage:$pagenum;
}
if($page+$pageoffset>$pagenum){
$start=$start-($page+$pageoffset-$end);
}
}
echo '';
if($page==$pagenum){
echo '
echo '
}else{
echo '
echo '
}
echo '
echo '
};
?>
在链接中加入 num=$num
把原来这句话 echo '
改成了这样echo '
在链接中加入 num=$num
改这样
<?phpfunction fenye($num){global $page,$pagenum,$shoupage,$pageoffset;echo "<div >";echo "<ul id='ul2'>";echo '<li>'.$page.'/'.$pagenum.'页|</li>'; if($page==1){ echo '<li>首页|</li>'; echo '<li>上一页|</li>'; }else{ echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'">首页</a>|</li>'; echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?'.($page-1).'&num='.$num.'">上一页</a>|</li>'; } $shoupage=5; $pageoffset=($shoupage-1)/2; $start=1; $end=$pagenum; if($pagenum>$shoupage){ if($page>$pageoffset){ $start=$page-$pageoffset; $end=$pagenum>$page+$pageoffset?$page+$pageoffset:$pagenum; }else{ $start=1; $end=$pagenum>$shoupage?$shoupage:$pagenum; } if($page+$pageoffset>$pagenum){ $start=$start-($page+$pageoffset-$end); } } echo '<div>'; echo '<ul id="ul1">'; for($i=$start;$i<=$end;$i++){ echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?page='.$i.'&num='.$num.'">'.($i).'</a></li>'; } echo '</ul>'; echo '</div>'; if($page==$pagenum){ echo '<li>|下一页|</li>'; echo '<li>尾页|</li>'; }else{ echo '<li>|<a href="'.$_SERVER["SCRIPT_NAME"].'?page='.($page+1).'&num='.$num.'">下一页</a>|</li>'; echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?page='.$pagenum.'&num='.$num.'">尾页</a>|</li>'; }echo '</ul>'; echo '</div>'; };?>
然后调用改这样
if($num || $page){
fenye($num);
}
?>
哈哈可以了 我先好好看看你的代码
改这样
<?phpfunction fenye($num){global $page,$pagenum,$shoupage,$pageoffset;echo "<div >";echo "<ul id='ul2'>";echo '<li>'.$page.'/'.$pagenum.'页|</li>'; if($page==1){ echo '<li>首页|</li>'; echo '<li>上一页|</li>'; }else{ echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'">首页</a>|</li>'; echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?'.($page-1).'&num='.$num.'">上一页</a>|</li>'; } $shoupage=5; $pageoffset=($shoupage-1)/2; $start=1; $end=$pagenum; if($pagenum>$shoupage){ if($page>$pageoffset){ $start=$page-$pageoffset; $end=$pagenum>$page+$pageoffset?$page+$pageoffset:$pagenum; }else{ $start=1; $end=$pagenum>$shoupage?$shoupage:$pagenum; } if($page+$pageoffset>$pagenum){ $start=$start-($page+$pageoffset-$end); } } echo '<div>'; echo '<ul id="ul1">'; for($i=$start;$i<=$end;$i++){ echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?page='.$i.'&num='.$num.'">'.($i).'</a></li>'; } echo '</ul>'; echo '</div>'; if($page==$pagenum){ echo '<li>|下一页|</li>'; echo '<li>尾页|</li>'; }else{ echo '<li>|<a href="'.$_SERVER["SCRIPT_NAME"].'?page='.($page+1).'&num='.$num.'">下一页</a>|</li>'; echo '<li><a href="'.$_SERVER["SCRIPT_NAME"].'?page='.$pagenum.'&num='.$num.'">尾页</a>|</li>'; }echo '</ul>'; echo '</div>'; };?>
然后调用改这样
if($num || $page){
fenye($num);
}
?>

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

phpstormでCLIモードをデバッグする方法は? PHPStormで開発するときは、PHPをコマンドラインインターフェイス(CLI)モードでデバッグする必要がある場合があります。

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。
