|
data:image/s3,"s3://crabby-images/9df89/9df89c83e8c1e31438585f2c965544b2676fc113" alt="" |
|
มีปัญหา เรื่อง Code แบ่งหน้าครับ รบกวนช่วยดูหน่อยครับ |
|
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
ผมไปก๊อปเอา code แบ่งหน้าจากตัวอย่างด้านล่างนี้ไปใช้ แล้วผมมีปัญหาตรงที่
url ของผมเป็นแบบนี้ index1.php?id=101113&st=1&sh=gal&by=0&page=1
ตรง page=1 ผมลองแก้เป็น page=0 หรือ page=-1 เพื่อส่งค่าที่ไม่มีจริงเข้าไป มันจะฟ้องแบบนี้ครับ
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in C:\AppServ
Warning: mysql_fetch_assoc(): supplied argument is not a valid MySQL result resource in C:\AppServ
และอีกปัญหาคือ ถ้าเราใส่ค่ามากกว่าจำนวนหน้าที่มันนับได้ ( สมมุตินับหน้า $total ได้ค่า page=14 )
และ url ของผมคือ index1.php?id=101113&st=1&sh=gal&by=0&page=14
ผมส่งค่าที่ไม่มีจริง ไปแทนคือ page=15
มันจะแสดง ออกมาแบบล่างนี้อ่ะครับ
« Previous 13 14 [127-126] of 125
มันจะแสดงค่า page ที่ไม่มีจริงออกมา และไม่สามารถดึงข้อมูลออกมาแสดงได้ เพราะ $_GET ค่าที่ไม่มีจริง
ที่ผมอยากได้คือ ผมอยากจะได้เงื่อนไข คือ ถ้าใส่ค่าที่ไม่มีจริงมา
เช่นถ้าใส่ page=0 หรือ page=-1 เข้ามา ก็ให้แสดงหน้าแรก คือ page=1 แทน
ถ้าใส่ page=15 ก็ให้แสดงหน้าสุดท้าย คือ page=14 แทน
ประมาณนี้อ่ะครับ รบกวนผู้รู้ช่วยแนะนำด้วยครับ
นี่ครับ ตัวแบ่งหน้า ที่ผม copy ไปใช้
Code (PHP)
<?php
#######################################################################
# $page = (isset($_GET['page']))? intval($_GET["page"]) : 0;
# $limit_end = 20;
# $limit_start = ($page-1)*$limit_end;
# $sql = "select * from table limit " . $limit_start. "," . $limit_end;
# page_navi($page, $limit_end, 4, 1000, "_self", "current_page", "other_page", $querystring);
#######################################################################
# $page = หน้าปัจจุบัน
# $limit= จำนวน record ต่อหน้า
# $range= บวกลบจากหน้าปัจจุบัน ใส่ 4 จะได้ตัวเลขออกมา 9
# $count= จำนวน record ทั้งหมด
# $send= ส่งตัวแปรอะไรไปด้วย
# $current_style = css สำหรับหน้าปัจจุบัน
# $other_style = css สำหรับอื่นๆ รวมถึง Prev Next First Last
# $target= อันนี้รู้ๆ กัน
#######################################################################
function page_navi($page, $limit, $range, $count, $send=NULL, $current_style="navi_on", $other_style="navi_out", $target="_self"){
$output = "";
$total = ceil($count/$limit);
$navi_start = $page-$range;
$navi_end = $page+$range;
$send .= (!empty($send))? "&" : NULL;
if($navi_start <= 0) $navi_start = 1;
if($navi_end >= $total) $navi_end = $total;
if($page>1){
$navi_back = $page-1;
if($page > 2)
$output .= "<a href=\"?" . $send . "page=1\" target=\"" . $target . "\" class=\"" . $other_style . "\"><strong>«</strong></a> ";
$output .= "<a href=\"?" . $send . "page=" . $navi_back . "\" target=\"" . $target . "\" class=\"" . $other_style . "\"><strong>‹</strong></a> ";
}
for($i = $navi_start; $i <= $navi_end; $i++){
if($i == $page)
$output .= "<a href=\"?" . $send . "page=" . $i . "\" target=\"" . $target . "\" class=\"" . $current_style . "\"><strong><font color=\"" . $other_style . "\">$i</font></strong></a> ";
else
$output .= "<a href=\"?" . $send . "page=" . $i . "\" target=\"" . $target . "\" class=\"" . $other_style . "\">$i</a> ";
}
if($page < $total){
$navi_next = $page+1;
$output .= "<a href=\"?" . $send . "page=" . $navi_next . "\" target=\"" . $target . "\" class=\"" . $other_style . "\"><strong>›</strong></a> ";
if(($page+1) < $total)
$output .= "<a href=\"?" . $send . "page=" . $total . "\" target=\"" . $target . "\" class=\"" . $other_style . "\"><strong>»</strong></a>";
}
if($navi_start>$navi_end)
$output .= "<a href=\"?" . $send . "page=" . $page . "\" target=\"" . $target . "\" class=\"" . $other_style . "\"><strong>$page</strong></a> ";
return $output;
}
?>
Code (PHP)
<?php
$page = (isset($_GET['page']))? intval($_GET['page']) : 1;
$limit_end = 2;
$limit_start = ($page-1)*$limit_end;
$send = "";
if(isset($_GET["id"]) and $_GET["id"] != ""){
$send = "id=" . $_GET["id"];
$condition= " WHERE category_id = '" . $_GET["id"] . "'";
}
$sql = "SELECT * FROM product" . $condition;
$query_id = mysql_query($sql . " LIMIT " . $limit_start. "," . $limit_end, $connection_id);
$count = mysql_num_rows($query_id);
$total = mysql_num_rows(mysql_query($sql, $connection_id));
if($total > 0){
while($rows = mysql_fetch_assoc($query_id)){
echo $rows["product_name"]."<br>";
}
echo "\n<div style=\"float:left;\">Page : " . page_navi($page, $limit_end, 4, $total, $send) . " </div><div style=\"float:right;\">[" . ($limit_start+1) . "-" . ($limit_start+$count) . "] of <strong>" . $total . "</strong></div>";
}
?>
Tag : - - - -
data:image/s3,"s3://crabby-images/f1944/f19447657087fec8fe853572ff7e2abde431999d" alt=""
|
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2009-12-05 22:15:57 |
By :
basic111 |
View :
940 |
Reply :
3 |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
คือผมไม่มีเวลามากนะ โทษทีคับ
if( ! $count) ไม่มีหน้า ให้แก้ sql ไปที่หน้า 1 ไม่ก็เอา error แสดง
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2009-12-05 22:27:20 |
By :
pjgunner |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
โคดนี้ต้องตามพี่ PlaKrim มาช่วยดู .... อ้ายอั๋นๆอยู่ไสๆ
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2009-12-06 00:46:34 |
By :
panyapol |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
data:image/s3,"s3://crabby-images/7fedc/7fedcaf09fd5bee73954d02b4483c86d0230d420" alt="" |
|
|
data:image/s3,"s3://crabby-images/e45aa/e45aaee0f4fc905d19252793523fee033b94fae1" alt="" |
data:image/s3,"s3://crabby-images/231a7/231a78f05c0c0ed37737b99e26cea23b39ccf6d3" alt="" |
|
Code (PHP)
if($total > 0){
if($count > 0){
while($rows = mysql_fetch_assoc($query_id)){
echo $rows["product_name"]."<br>";
}
echo "\n<div style=\"float:left;\">Page : " . page_navi($page, $limit_end, 4, $total, $send) . " </div><div style=\"float:right;\">[" . ($limit_start+1) . "-" . ($limit_start+$count) . "] of <strong>" . $total . "</strong></div>";
}else{
echo "ไม่พบข้อมูล";
}
}else{
echo "ไม่พบข้อมูล";
}
แนะนำให้ฟ้องเออเร่อดีกว่าครับ
ถ้าจะทำจริงๆ มันหลายขั้นตอนเปลืองเปล่าๆ
|
data:image/s3,"s3://crabby-images/e1105/e1105d0e74a2d0eb06807f9a8bb7837265dd1b25" alt="" |
data:image/s3,"s3://crabby-images/92e09/92e0905a512f79cb2effe389f0706c0250452af0" alt="" |
data:image/s3,"s3://crabby-images/693ac/693ac66a71272d9b5660bb393d6a6a04364e4b31" alt="" |
data:image/s3,"s3://crabby-images/d2a47/d2a4711f1cb0ada479d82db711d17ea838ad4608" alt="" |
Date :
2009-12-06 13:08:25 |
By :
plakrim |
|
data:image/s3,"s3://crabby-images/8ff8f/8ff8f25048dbb4f7de5f0118d14bcabdc18143ef" alt="" |
data:image/s3,"s3://crabby-images/7fd72/7fd72b1fac36218a06fb8209da6ac85fd043bc59" alt="" |
data:image/s3,"s3://crabby-images/cb795/cb79529c393c790a02b4efc08e9785df7594357b" alt="" |
data:image/s3,"s3://crabby-images/86f8b/86f8b258aff3f9b396166d63cdd10a0bdaa6a65b" alt="" |
|
|
data:image/s3,"s3://crabby-images/5416e/5416e7b34fe0f455da9044a6446378b16b8e0b2b" alt="" |
data:image/s3,"s3://crabby-images/84116/841160e53c788c51332da0ac62480d0c293dc438" alt="" |
|
data:image/s3,"s3://crabby-images/8a41b/8a41b2577cb9d0716104f821c8da48a5a3adeb45" alt="" |
data:image/s3,"s3://crabby-images/fc71b/fc71b0128ed13d03ddb4422fb4f7a3f7f2deb2e4" alt="" |
|
|
|
data:image/s3,"s3://crabby-images/f3b89/f3b89ccde25850c65b928bee7cddda844ab028bb" alt=""
|
Load balance : Server 03
|