|
|
|
ถามเรื่อง function แบ่งหน้า page ครับผมยังไม่เคยทำ ไม่เข้าใจว่ามันเรียกใช้ยังไงครับ |
|
|
|
|
|
|
|
อยากแบ่งหน้าข้อมูลเป็นส่วน ๆ ครับ
แล้วผมสร้าง เป็น function แยกไว้ไฟล์นึง (ทำตามในเว็บ แบบงง ๆ)
แบบนี้ครับ
ไฟล์ functionLib.php
<?
function displayPaging( $total, $limit, $pagenumber, $baseurl ){
// how many page numbers to show in list at a time
$showpages = "10"; // 1,3,5,7,9...
// set up icons to be used
$icon_path = 'icons/';
$icon_param = 'align="middle" style="border:0px;" ';
$icon_first= '[First page]';
$icon_last= '[Lastpage]';
$icon_previous= '<< Previous';
$icon_next= 'Next >>';
// do calculations
$pages = ceil($total / $limit);
$offset = ($pagenumber * $limit) - $limit;
$end = $offset + $limit;
// prepare paging links
$html .= '<div id="pageLinks">';
// if first link is needed
if($pagenumber > 1) { $previous = $pagenumber -1;
$html .= '<a href="'.$baseurl.'1">'.$icon_first.'</a> ';
}
// if previous link is needed
if($pagenumber > 2) { $previous = $pagenumber -1;
$html .= '<a href="'.$baseurl.''.$previous.'">'.$icon_previous.'</a> ';
}
// print page numbers
if ($pages>=2) { $p=1;
$html .= "| Page: ";
$pages_before = $pagenumber - 1;
$pages_after = $pages - $pagenumber;
$show_before = floor($showpages / 2);
$show_after = floor($showpages / 2);
if ($pages_before < $show_before){
$dif = $show_before - $pages_before;
$show_after = $show_after + $dif;
}
if ($pages_after < $show_after){
$dif = $show_after - $pages_after;
$show_before = $show_before + $dif;
}
$minpage = $pagenumber - ($show_before+1);
$maxpage = $pagenumber + ($show_after+1);
if ($pagenumber > ($show_before+1) && $showpages > 0) {
$html .= " ... ";
}
while ($p <= $pages) {
if ($p > $minpage && $p < $maxpage) {
if ($pagenumber == $p) {
$html .= " <b>".$p."</b>";
} else {
$html .= ' <a href="'.$baseurl.$p.'">'.$p.'</a>';
}
}
$p++;
}
if ($maxpage-1 < $pages && $showpages > 0) {
$html .= " ... ";
}
}
// if next link is needed
if($end < $total) { $next = $pagenumber +1;
if ($next != ($p-1)) {
$html .= ' | <a href="'.$baseurl.$next.'">'.$icon_next.'</a>';
} else {$html .= ' | ';}
}
// if last link is needed
if($end < $total) { $last = $p -1;
$html .= ' <a href="'.$baseurl.$last.'">'.$icon_last.'</a>';
}
$html .= '</div>';
// return paging links
return $html;
}
?>
แล้ว index เป็นแบบนี้ครับ
index (PHP)
<?php
include_once '../includes/connect.php';
include_once '../includes/functionLib.php';
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
<table width="100%" border="0" align="left" cellpadding="0" cellspacing="0" bgcolor="#dedbd1">
<tr>
<td><table width="100%" border="0" align="center" cellpadding="0" cellspacing="1">
<tr>
<td width="10%" height="29" align="center" bgcolor="#ebe9e1"><strong>#</strong></td>
<td width="12%" height="29" align="center" bgcolor="#ebe9e1"><strong>ชื่อ</strong></td>
<td width="12%" align="center" bgcolor="#ebe9e1"><strong>สถานะ</strong></td>
<td width="12%" height="29" align="center" bgcolor="#ebe9e1"><strong>Edit</strong></td>
<td width="12%" height="29" align="center" bgcolor="#ebe9e1"><strong>Delete</strong></td>
</tr>
<tr>
<?
displayPaging( $total, $limit, $pagenumber, $baseurl );
$result = mysql_query("SELECT * FROM pool order by id asc");
$total = mysql_num_rows($result);
?>
<? while($row = mysql_fetch_array($result)) { ?>
<tr>
<td height="29" align="center" bgcolor="#FFFFFF" ><?=$row["id"]?></td>
<td height="29" align="center" bgcolor="#FFFFFF" ><?=$row["name"]?></td>
<td height="29" align="center" bgcolor="#FFFFFF" ><?=$row["status"]?></td>
<td height="29" align="center" bgcolor="#FFFFFF" >Edit</td>
<td height="29" align="center" bgcolor="#FFFFFF" >Delete</td>
</tr>
<? } ?>
</table></td>
</tr>
</table><br />
</body>
</html>
ผมจะเรียกใช้ function จาก หน้า index ยังไงหรอครับ รบกวนด้วยครับ ขอบคุณครับ
Tag : PHP, MySQL
|
|
|
|
|
|
Date :
2010-08-30 17:17:08 |
By :
junior_dev |
View :
3022 |
Reply :
6 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
แบบนี้ ผมต้องใส่ทุก ๆ หน้าใช่ป่ะครับ
|
|
|
|
|
Date :
2010-08-30 17:24:41 |
By :
junior_dev |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ผมเรียกใช้
Code (PHP)
displayPaging();
ไม่ได้อ่ะครับ
|
|
|
|
|
Date :
2010-08-30 17:43:48 |
By :
junior_dev |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ขอบคุณมากเลยครับ เดี๋ยวลองทำดู ดีจังเลยเว็บนี้คนเก่งๆทั้งนั้น เหมือนมีที่ปรึกษาเป็นอาจารย์เลย
|
|
|
|
|
Date :
2010-08-30 23:16:32 |
By :
Nut_M |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ผมต้องใช้ การแบ่งหน้าแบบนี้หลาย ๆ ครั้งอ่ะครับ ก็เลยแยก ฟังก์ชั่น ไส้เรียกใช้ แต่ทำยังไงอ่ะครับ เรียกใช้ไม่เป็น ?
หรือมีวิธีการเขียน ที่ดีกว่านี้แนะนำมั๊ยครับผม ไม่งั้นผมต้องมานั่งแทรกโค๊ด ทีละหน้า ๆ เลยอ่ะครับ
|
|
|
|
|
Date :
2010-08-31 09:59:25 |
By :
junior_dev |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
displayPaging( $total, $limit, $pagenumber, $baseurl )
$total = จำนวนข้อมูลทั้งหมด
$limit = จำนวนข้อมูลต่อ 1 หน้า
$pagenumber = เลขหน้าปัจจุบัน
$baseurl = Parameter ต่าง ๆ แต่ Parameter สุดท้ายต้องเป็น page=
วิธีการใช้
echo displayPaging( count($arrayRows), 10, (isset($page) == null)?1:$page, 'index.php?page=');
|
|
|
|
|
Date :
2010-08-31 10:35:03 |
By :
burn |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Load balance : Server 04
|