Maison >développement back-end >tutoriel php >smarty分页的例子

smarty分页的例子

WBOY
WBOYoriginal
2016-07-25 09:10:301530parcourir
  1. @session_start();
  2. require_once("smarty.php");//加载smarty模板类
  3. require_once("adodb/adodb.inc.php");//加载adodb数据库
  4. //连接数据库

  5. $dbhost = 'localhost'; // 数据库服务器
  6. $dbuser = 'root'; // 数据库用户名
  7. $dbpwd= 'root'; // 数据库密码
  8. $dbname='hejia'; //数据库名称
  9. $conn = NewAdoConnection('mysql'); // 建立连接对象

  10. $conn->Connect($dbhost, $dbuser, $dbpwd, $dbname); //连接数据库
  11. $conn->Query("Set Names 'gb2312'");//来源于mysql_query("SET NAMES GBK");
  12. date_default_timezone_set(PRC); //PHP获取时间差8小时的解决办法,也可在php.ini里修改date.timezone为PRC
  13. ?>
复制代码

首页 index.php:

  1. require_once("const.php");
  2. $sql1="select id,hits,title,add_date from oa_art order by id desc"; //SQL语句
  3. $pageSize=4; //设置每页记录数
  4. $sql=$sql1." limit ".($pageSize * ((empty($_REQUEST['page']) ? 1 : $_REQUEST['page'])-1)).", ".$pageSize;
  5. $news_array=$conn->getall($sql);
  6. $news_array1=$conn->getall($sql1);
  7. $page_url="index.php"; //页面url地址
  8. $totalnumber=count($news_array1); //获得总记录数
  9. $midPage=5; //数字导航链接数
  10. page();// 调用分页函数
  11. for ($i = 0; $i $smarty->assign("page_option",$page_option);

  12. $smarty->assign("news_data",$news_array);

  13. $smarty->assign("mytitle","企业网站首页");
  14. $smarty->display("tpl.htm",$page);
  15. ?>
复制代码

分页函数:

  1. function page()

  2. {
  3. global $smarty,$start,$page_url,$pageSize,$midPage,$totalnumber;
  4. $total = $totalnumber ; //获得总记录数
  5. $totalPage = ceil($total/$pageSize); //获得总页数
  6. $currentPage=@$_REQUEST['page']+0; //当前页
  7. if(!is_numeric($currentPage) || $currentPage $totalPage)
  8. $currentPage=1; //初始化当前页
  9. $url = preg_replace(array("!(([&]|^)(page)[=]?([^&]+)?)|((([&]){2,})|(^[&])|([&]$))!",),array(""),$_SERVER["QUERY_STRING"]); // 设置地址,正则替换掉
  10. $url.=($url?"&":"").'page'; // 追加
  11. $start = ($currentPage-1)*$pageSize;
  12. $back = $currentPage > 1?"\n":"";
  13. $next = $currentPage >>\n":"";
  14. $first = $currentPage > 1?"首页\n":"";
  15. $last = $currentPage 尾页\n":"";
  16. // 导航链接

  17. $midPages = '';
  18. $num = $currentPage-floor($midPage/2);
  19. if($num > 0)
  20. {
  21. if(($totalPage-$num) {
  22. $tmp = $totalPage - $midPage;
  23. $num = $tmp }
  24. }else $num = 1;
  25. for($i=1; $i {
  26. if($num > $totalPage) break;
  27. $midPages .= ($num == $currentPage) ? '['.$num.'] ' : "".$num." ";
  28. }
  29. $smarty->assign("page_total",$total); // 总计
  30. $smarty->assign("page_currentPage",$currentPage); // 当前页码
  31. $smarty->assign("page_totalPage",$totalPage); // 总页数
  32. $smarty->assign("page_back",$back); // 上一页
  33. $smarty->assign("page_next",$next); // 下一页
  34. $smarty->assign("page_first",$first); // 首页
  35. $smarty->assign("page_last",$last); // 尾页
  36. $smarty->assign("page_midPages",$midPages); // 中间页
  37. $smarty->assign("page_url",$page_url); // 当前页地址
  38. }
  39. ?>
复制代码

模板页 tpl.htm:

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn