程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> Thinkphp搜索時首頁分頁和搜索頁保持條件分頁的方法

Thinkphp搜索時首頁分頁和搜索頁保持條件分頁的方法

編輯:PHP綜合

本文實例講述了Thinkphp實現搜索時首頁分頁和搜索頁保持條件分頁的方法。分享給大家供大家參考。具體實現方法如下:

在做搜索查詢時突然發現在首頁用的分頁代碼在搜索頁使用時出現錯誤,首頁分頁代碼(代碼中標注start與end部分為分頁代碼)
復制代碼 代碼如下:public function index(){
  $res=D('Info');// 實例化Data數據對象

  /**********start************/
  import('ORG.Util.Page');// 導入分頁類
  $count= $res->count();// 查詢滿足要求的總記錄數
  $Page = new Page($count,3);// 實例化分頁類 傳入總記錄數(另一個參數為自定義分頁條數)
  //$Page->rollPage = 3;//默認情況下,頁面顯示的頁數是5  可以修改
  $show= $Page->show();// 分頁顯示輸出
  // 進行分頁數據查詢
  $list = $res->order('iid desc')->limit($Page->firstRow.','.$Page->listRows)->select();
  /**********end************/

  $this->assign('list',$list);// 賦值數據集

  /*********start*************/
  $this->assign('page',$show);// 賦值分頁輸出
  /*********end*************/

  $this->display(); // 輸出模板
}
搜索代碼(代碼中start與end之間標注的部分為分頁代碼,注釋標注了分頁跳轉時保存查詢條件),以下兩種方法都可以保存條件(不清楚這樣是不是寫的規范),查詢:
復制代碼 代碼如下:public function search() {
   $res=D('Info');
   $name=$_REQUEST['name'];
   $sear['name'] = array('like','%'.$name.'%');

   /*********start*************/
   import('ORG.Util.Page');// 導入分頁類
   $count=$res->where($sear)->count();//查詢數據條數
   $Page=new Page($count,2);//實例化分頁函數
   /*********end*************/

   //分頁跳轉的時候保存查詢條件
   foreach($sear as $key=>$val) {
    $Page->parameter   .=   "$key=".urlencode($name)."&";//賦值給Page
   }

   /*********start*************/
   $show=$Page->show();//分頁顯示輸出
   // 進行分頁數據查詢
    $val=$res->where($sear)->$val=$res->where($sear)->limit($Page->firstRow.','.$Page->listRows)->select();
    /*********end*************/

   $this->assign('search',$val);

   /*********start*************/
   $this->assign('page',$show);
   /*********end*************/

   $this->display();
}
注:
復制代碼 代碼如下:   foreach($sear as $key=>$val) {
    $Page->parameter   .=   "$key=".urlencode($name)."&";//賦值給Page
   }
   "$key=".urlencode($name)."&";這裡面的$name 相對應提取的是 $name=$_REQUEST['name'];獲取的值。

第二種:
復制代碼 代碼如下:public function search() { 
   $res=D('Info'); 
   $name=$_REQUEST['name']; 
   $sear['name'] = array('like','%'.$name.'%'); 
   import('ORG.Util.Page');// 導入分頁類 
   $count=$res->where($sear)->count();//查詢數據條數 
   $Page=new Page($count,2);//實例化分頁函數 
   //分頁跳轉的時候保證查詢條件 
   foreach($sear as $key=>$val) {     
    $Page->parameter   .=   "$key=".urlencode($val[1]).'&'; 
   } 
   $show=$Page->show();//分頁顯示輸出 
   // 進行分頁數據查詢 
   $val=$res->where($sear)->limit($Page->firstRow.','.$Page->listRows)->select(); 
   $this->assign('search',$val); 
   $this->assign('page',$show); 
   $this->display(); 
}
使用$val[1]是因為$sear是一個數組,而$val[1]對應的是我要查找的條件,這樣就可以保持條件進行分頁了.

更多關於thinkPHP相關內容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》及《ThinkPHP常用方法總結》

希望本文所述對大家基於ThinkPHP框架的PHP程序設計有所幫助。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved