本文實例講述了Thinkphp實現(xiàn)搜索時首頁分頁和搜索頁保持條件分頁的方法。分享給大家供大家參考。具體實現(xiàn)方法如下:
在做搜索查詢時突然發(fā)現(xiàn)在首頁用的分頁代碼在搜索頁使用時出現(xiàn)錯誤,首頁分頁代碼(代碼中標注start與end部分為分頁代碼)
public function index(){
$res=D('Info');// 實例化Data數(shù)據(jù)對象
/**********start************/
import('ORG.Util.Page');// 導(dǎo)入分頁類
$count= $res->count();// 查詢滿足要求的總記錄數(shù)
$Page = new Page($count,3);// 實例化分頁類 傳入總記錄數(shù)(另一個參數(shù)為自定義分頁條數(shù))
//$Page->rollPage = 3;//默認情況下,頁面顯示的頁數(shù)是5 可以修改
$show= $Page->show();// 分頁顯示輸出
// 進行分頁數(shù)據(jù)查詢
$list = $res->order('iid desc')->limit($Page->firstRow.','.$Page->listRows)->select();
/**********end************/
$this->assign('list',$list);// 賦值數(shù)據(jù)集
/*********start*************/
$this->assign('page',$show);// 賦值分頁輸出
/*********end*************/
$this->display(); // 輸出模板
}
搜索代碼(代碼中start與end之間標注的部分為分頁代碼,注釋標注了分頁跳轉(zhuǎn)時保存查詢條件),以下兩種方法都可以保存條件(不清楚這樣是不是寫的規(guī)范),查詢:
public function search() {
$res=D('Info');
$name=$_REQUEST['name'];
$sear['name'] = array('like','%'.$name.'%');
/*********start*************/
import('ORG.Util.Page');// 導(dǎo)入分頁類
$count=$res->where($sear)->count();//查詢數(shù)據(jù)條數(shù)
$Page=new Page($count,2);//實例化分頁函數(shù)
/*********end*************/
//分頁跳轉(zhuǎn)的時候保存查詢條件
foreach($sear as $key=>$val) {
$Page->parameter .= "$key=".urlencode($name)."&";//賦值給Page
}
/*********start*************/
$show=$Page->show();//分頁顯示輸出
// 進行分頁數(shù)據(jù)查詢
$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();
}
注:
$Page->parameter .= "$key=".urlencode($name)."&";//賦值給Page
}
"$key=".urlencode($name)."&";
這里面的$name 相對應(yīng)提取的是 $name=$_REQUEST['name'];獲取的值。
第二種:
$res=D('Info');
$name=$_REQUEST['name'];
$sear['name'] = array('like','%'.$name.'%');
import('ORG.Util.Page');// 導(dǎo)入分頁類
$count=$res->where($sear)->count();//查詢數(shù)據(jù)條數(shù)
$Page=new Page($count,2);//實例化分頁函數(shù)
//分頁跳轉(zhuǎn)的時候保證查詢條件
foreach($sear as $key=>$val) {
$Page->parameter .= "$key=".urlencode($val[1]).'&';
}
$show=$Page->show();//分頁顯示輸出
// 進行分頁數(shù)據(jù)查詢
$val=$res->where($sear)->limit($Page->firstRow.','.$Page->listRows)->select();
$this->assign('search',$val);
$this->assign('page',$show);
$this->display();
}
使用$val[1]是因為$sear是一個數(shù)組,而$val[1]對應(yīng)的是我要查找的條件,這樣就可以保持條件進行分頁了.
希望本文所述對大家基于ThinkPHP框架的PHP程序設(shè)計有所幫助。