thinkphp分頁時保持查詢條件

來源:互聯網
上載者:User

標籤: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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.