ホームページ >バックエンド開発 >PHPチュートリアル >thinkphp のクエリとページングに関する質問
コントローラ内の検索方法:
public function search(){ import("@.ORG.Page"); $list = D('Blog'); $keyword = trim($this->_post('keyword','htmlspecialchars')); $sql = "SELECT b.*, a.`content`, u.`username` FROM blog b LEFT JOIN blog_attribute a ON a.`blog_id`=b.`id` LEFT JOIN user u ON u.`id`=b.`user_id` "; if(!empty($keyword)){ $sql .= " WHERE b.`title` LIKE '%{$keyword}%' OR a.`content` LIKE '%{$keyword}%'"; } $count = count($list->query($sql)); $Page = new Page($count,2); $firstRow = $Page->firstRow; $listRows = $Page->listRows; $this->data = $list->searchBlog($sql,$firstRow,$listRows); $xxx['data'] = $this->data; $page = $Page->show(); $xxx['page'] = $page; //$this->data['page'] = $page; //$this->assign("page",$page); //var_dump(urldecode(json_encode($this->data))); $this->show(urldecode(json_encode($xxx))); }
<import type="css" file="Css.rightContent" /><import type="js" file="js.jquery_min" /><script type="text/javascript">$(document).ready(function(){ $("button").click(function(){ var keyword = $(this).parent("div").children("input").val(); $.ajax({ url: "{:U('Blog/search')}", type: "POST", data: {"keyword":keyword}, error:function(e){ alert("查询出错!"); }, success:function(data){ $("#cell_tb_list").empty(); if(data != ""){ data = eval('('+data+')'); //alert(data.data.length); var layer = "<table class=\"has_checkbox\">"; layer += "<colgroup>"; layer += "<col class=\"col1\">"; layer += "<col class=\"col2\">"; layer += "<col class=\"col3\">"; layer += "<col class=\"col4\">"; layer += "<col class=\"col5\">"; layer += "</colgroup>"; layer += "<tbody>"; layer += "<tr class=\"hoverout\">"; layer += "<th class=\"td2\">发布人</th>"; layer += "<th class=\"td2\">博客标题</th>"; layer += "<th class=\"td2\">发布时间</th>"; layer += "<th class=\"td2\">更新时间</th>"; layer += "<th class=\"td2\">操作</th>"; layer += "</tr>"; for(var i=0;i<data.data.length;i++){ layer += "<tr id=\"testhere\">"; layer += "<td>"+data.data[i].username+"</td>"; layer += "<td>"+data.data[i].title+"</td>"; layer += "<td>"+data.data[i].create_time+"</td>"; layer += "<td>"+data.data[i].update_time+"</td>"; layer += "<td>修改|删除</td>"; layer += "</tr>"; } layer += "<tr class=\"hoverout\" ><td colspan=\"6\" id=\"td_click\" style=\"text-align:right;\">"+data.page+"</td></tr>"; layer += "</tbody>"; layer += "</table>"; // var layer = "<h1>"+data[0].create_time+"</h1>"; $("#cell_tb_list").append(layer); }else{ alert("no"); } } }); });});</script><div id="stage" class="content"> <div id="main"> <div class="title"> <div class="m_bg">博客列表页</div> </div> <div class="mainContent"> <div class="main_content"> <div class="location"> <div class="location_main item"> <div class="search_main"> <!--<form action="__URL__/search" id="search_form" method="post">--> <input type="text" id="query_input" class="search input_txt" name="query_keyword"> <button class="btn" title="Submit Search" type="submit"></button> <!--</form>--> </div> </div> </div> <div class="cell_tb_list" id="cell_tb_list"></div> </div> </div> </div></div>
誰か見てますか?
は、サーバー側のデータを取得するために ajax を使用することです。次のページネーションをクリックすると、返された JSON データを確認できます。または、バックグラウンドで直接デバッグし、いくつかのパラメーターを指定して、サーバー側でデータが正常かどうかを確認することもできます。
は、ajax を使用してサーバー側のデータを取得することです。次のページネーションをクリックすると、返された JSON データを確認できます。または、バックグラウンドで直接デバッグし、いくつかのパラメーターを指定して、サーバー側でデータが正常かどうかを確認することもできます。
次のページをクリックする前にページクラスを変更する必要があります。そうしないと、Spring Json 形式が出力
2 ページ目に返されたデータは異常ですか? バックエンドでデバッグするのが最善です。
区切り記号と何か関係があるのでしょうか? {} を d0caa276b7a674bb589eb7da91e64d11 に置き換えてみてください
http://dadaboke.com 何度も使用していますが、スタイルを自分で変更することもできます。 。
ajax を介して送信して返すので、これを行う方法はないようです。
$(function(){ $('.page a').click(function(){ $.get($(this).attr('href'),function(data){ $('#index_content').html(data); }) return false; }) })という別の解決策があります。データを取得した後、フォーマットに従って処理します。試してみても大丈夫です
こちらの記事をご覧ください http://www.23kaiyuan.com/516.html