ホームページ >バックエンド開発 >PHPチュートリアル >PHP アンチ Google ページング効果コード_PHP チュートリアル
function getPageRange($currentPage, $totalPages, $displaySize = 10) {
if ($totalPages return array();
} elseif ($displaySize > $ totalPages) {
$startPage = 1;
$endPage = $totalPages;
} else {
if ($currentPage % $displaySize === 0) {
$startPage = $currentPage - $displaySize + 1 ;
} else {
while (($currentPage % $displaySize)) {
--$currentPage;
}
$startPage = $currentPage + 1;
}
if ($startPage $startPage = 1;
}
$endPage = $startPage + $displaySize - 1;
if ($endPage > $totalPages) {
$endPage = $totalPages;
$startPage = $endPage - $displaySize + 1;
}
}
戻り範囲( $startPage, $endPage);
}関数getPageRange は、現在のページ数 $currentPage、合計数 $totalPages、および翻訳領域の長さ $displaySize の 3 つのパラメータを受け取り、承認は 10 です。 $currentPage を含む適切なターンテーブルを生成します。 まず、法外のパラメータ値を除外し、全体のセクション数またはセクション長が 0 より小さい場合に備えて検査を続けます。前述したように、翻訳セクションの長さを決定した後、すべてのセクション長を分析して、すべてのセクションに同じ数値が含まれているわけではないことを確認できます。幸いなことに、これは私たちの核心に影響を与えるものではありませんが、私たちは、決められた翻訳セクションの長さを下回る可能性があります。したがって、私たちは、核心の問題を解決する前に、最初に最終的な状況を検討し、1 つの領域のみを迅速に捕捉します。次に、領域の固有のプロパティを確認します。動的に切断された領域には、開始端と尾端があり、領域間には前後の順序があるため、静的な分を経て、最初の(首)区と最後の(尾)区に到達します。しかしながら、最初のブロック間隔を重ねてみると、総数が、決められたターンテーブル間隔よりも小さいことが分かる。 PHP 内にある range 関数は、セクション内のすべてのコードを生成します。
アルゴリズムは、現在のトップ $currentPage と翻訳セクションの長さ $displaySize を利用して、現在のトップがセクション内にある位置を判断し、さらにセクション間の開始と完全な無劣化を実現するためには、境界がはみ出す問題も考慮していますが、これも非常に単純で、最初のピンと最後のピンが 1 と全体の数の間にあるかどうかを判断するだけで十分です。ここまでで、コードの分析は完了しました。 次のアルゴリズムの 時間効率を見てみましょう。俗に、アルゴリズムの基本的な操作は要求モードであり、メソッドの実行時間は $currentPage と $displaySize の差によって決まります。値が大きいほど、要求する倍数が多く、実行時間が長くなり、プレゼンス構造になります。したがって、実行結果は短時間で完了します。 getPageRange関数数生成一翻訳区间、入力に必要なパラメータ:print_r(implode(',', getPageRange(18, 27, 20)));得られた結果は:
1,2,3,4,5,6 、7、8、9、10、11、12、13、14、15、16、17、18、19、20 は、Google の翻訳のため、これと Google 検索結果の表示とはまったく異なります。嗯、不要灰心、我们仍可用getPageRange関数数得到之相一致的結果,必要把问题再分解一下:
print_r(implode(',', array_merge(getPageRange(17, 17, 10), getPageRange(27, 27, 10))));得られた結果は:
8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27