標籤:style http 使用 os strong 資料 io for
thinkphp 查詢資料時需要分頁顯示時,會出現只有第1頁是按查詢條件查到的資料,而其他頁面都恢複了,我們想要的結果卻是:在翻頁時,查詢條件保持不變。
原因是:在分頁跳轉的時候,沒有將查詢條件作為分頁參數傳遞到下一頁。原來翻頁的時候,儲存在REQUEST變數中的參數並未被傳遞到下一頁,因為表單的 method = “post”,而點擊進入下一頁時,很明顯form表單被重設了,所以列印REQUEST變數也是空的。
thinkphp RBAC的範例程式碼中給出了:
PHP $p = new Page($count, $listRows);//分頁查詢資料$voList = $model->where($map)->order("`" . $order . "` " . $sort)->limit($p->firstRow . ‘,‘ . $p->listRows)->findAll();//echo $model->getlastsql();//分頁跳轉的時候保證查詢條件(其實重點不在這裡!)foreach ($map as $key => $val) {if (!is_array($val)) {$p->parameter .= "$key=" . urlencode($val) . "&";}}//分頁顯示$page = $p->show();
| 12345678910111213 |
$p = new Page($count, $listRows);//分頁查詢資料$voList = $model->where($map)->order("`" . $order . "` " . $sort)->limit($p->firstRow . ‘,‘ . $p->listRows)->findAll(); //echo $model->getlastsql();//分頁跳轉的時候保證查詢條件(其實重點不在這裡!)foreach ($map as $key => $val) {if (!is_array($val)) {$p->parameter .= "$key=" . urlencode($val) . "&";}}//分頁顯示$page = $p->show(); |
試過之後,發現雖然試圖在URL參數中加入查詢條件,但是顯示的結果仍然如初,因為翻到第二頁時,查詢條件的表單資料已經丟失了。
查看ORG.page類,發現其parameter屬性確實是由使用者表單輸入的查詢條件和系統內定的分頁參數p經過urlencode最後附加到頁碼跳轉的連結URL上。儘管thinkphp官方說,會優先去POST,再去GET變數,但是結果卻並非想象中那麼美好。
在模版中,將查詢條件的表單提交方式,由POST方式 改為 GET 方式 ,即:method = “get”,問題暫時解決了。
待續…
2013.11.27
今天有了一些新的想法。不知道這種方式好不好。
1、在使用了條件查詢時,將查詢條件發送到action,
2、action在調用view顯示頁面時,再把查詢條件欄位寫到頁面上。
3、重複1操作。
thinkphp