ホームページ  >  記事  >  バックエンド開発  >  thinkphp のクエリとページングに関する質問

thinkphp のクエリとページングに関する質問

WBOY
WBOYオリジナル
2016-06-23 13:31:491032ブラウズ

コントローラ内の検索方法:

	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>

私の個人的な考えは、リストページをクリックすると、検索ボックスが表示され、検索情報を入力すると、検索された情報が表示されます。現在のページに表示され、ページネーションが追加されました。ページングの各ページは、現在のページの下に表示されます。
この場合、リストの最初のページは実際には正常ですが、その後のページネーションをクリックすると、そのページが表示されます
私は初心者なので、これについてはあまり知りません。方法を理解するのを手伝っていただければ幸いです。ページネーションが正常になるように変更します。ページング クラスはオリジナルの thinkphp であり、スタイルに若干の変更が加えられています。


ディスカッションへの返信 (解決策)

誰か見てますか?

は、サーバー側のデータを取得するために ajax を使用することです。次のページネーションをクリックすると、返された JSON データを確認できます。または、バックグラウンドで直接デバッグし、いくつかのパラメーターを指定して、サーバー側でデータが正常かどうかを確認することもできます。

は、ajax を使用してサーバー側のデータを取得することです。次のページネーションをクリックすると、返された JSON データを確認できます。または、バックグラウンドで直接デバッグし、いくつかのパラメーターを指定して、サーバー側でデータが正常かどうかを確認することもできます。


私の最後の写真は 2 番目のページをクリックした結果であり、返されたデータは 2 番目のページのデータです

次のページをクリックする前にページクラスを変更する必要があります。そうしないと、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;     }) }) 
という別の解決策があります。データを取得した後、フォーマットに従って処理します。試してみても大丈夫です

これは簡単に実装できるはずですよね?問題を解決するには 2 つのテンプレートを作成するだけです。それほど複雑である必要はありません。

こちらの記事をご覧ください http://www.23kaiyuan.com/516.html

投稿者は問題をどのように解決しましたか?

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。