JSON PHP中返回JSON数据(多个JSON通过一个大的数组组合成一个JSON字符串),在客户端解析JSON数据减轻服务端压力
data.php(服务端通过一个大的索引数组拼装多个JSON数据成一个大的JSON字符串,只能返回这一个大的JSON字符串):
<?php
header("content-type:text/html;charset=utf-8");
//实现传统分页效果
//连接数据库、获得数据、分页显示
$link = mysql_connect("localhost","root","123456");
mysql_select_db("shop0811", $link);
mysql_query("set names utf8");
//数据分页实现
//① 引入分页工具类
include("./page.class.php");
//② 获得记录总条数/每页显示条数设置
$sql = "select * from sw_goods";
$qry = mysql_query($sql);
$cnt = mysql_num_rows($qry); //数据总条数
$per = 7;//每页显示7条
//③ 实例化分页类对象
$page_obj = new Page($cnt, $per);
//④ 拼装sql语句,获得每页信息
$sql3 = "select goods_name n,goods_price p,goods_number m,goods_weight w from sw_goods ".$page_obj->limit;
$qry3 = mysql_query($sql3);
//⑤ 获得页码列表
$pagelist = $page_obj -> fpage(array(3,4,5,6,7,8));
$p = isset($_GET["page"])?$_GET["page"]:1;
$i = ($p-1)*$per+1; //(页码-1)*每页条数+1
$info = array();//声明一个数组,最终把全部数据都集中在此数组里边
while($rst3 = mysql_fetch_assoc($qry3)){
$rst3["xu"] = $i++;
$info[] = $rst3; //通过$info[]索引数组拼装JSON数据。
}
$info[] = $pagelist;//页面列表。通过$info[]索引数组拼装多个JSON数据。$info[]是索引数组,在PHP中索引数组会序列化成JavaScript的数组-->[{第一条数据},{第二条数据},{第三条数据},"pageList字符串"]
echo json_encode($info);
//把全部数据通过json格式提供出来
//json_encode()只允许使用一次
//这就要求把提供的信息组织为一个大的数组
index.html(浏览器端解析大的JSON数据,减轻服务端压力):<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>新建网页</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="description" content="" />
<meta name="keywords" content="" />
<script type="text/javascript">
//通过ajax获得分页信息
function showpage(url){
var xhr = new XMLHttpRequest();
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
eval("var jn_info="+xhr.responseText); //eval函数将字符串当成代码来执行(去掉两端的引号)(PHP索引数组的JSON字符串-->JavaScript数组(jn_info))
//遍历二维信息
var s = "<table><tr><td>序号</td><td>名称</td><td>价格</td><td>数量</td><td>重量</td></tr>";
for(var i=0; i<jn_info.length-1; i++){ //length-1是因为大的数组中的最后一个元素是一个pageList字符串。
jn_info[i]
s += "<tr>";
s += "<td>"+jn_info[i].xu+"</td>";
s += "<td>"+jn_info[i].n+"</td>";
s += "<td>"+jn_info[i].p+"</td>";
s += "<td>"+jn_info[i].m+"</td>";
s += "<td>"+jn_info[i].w+"</td>";
s += "</tr>";
}
s += "<tr><td colspan="5">"+jn_info[jn_info.length-1]+"</td></tr>"; //jn_info[jn_info.length-1] 数组中的最后一个元素是pageList字符串。
s += "</table>";
//把获得服务器JSON信息显示到id=result的div里边
document.getElementById("result").innerHTML = s;
}
}
xhr.open("get",url);
xhr.send(null);
}
//页面加载完毕就获得一次分页信息
window.onload = function(){
showpage("./data.php?page=1");
}
</script>
<style type="text/css">
h2 {width:700px;margin:auto;text-align:center;}
table {width:700px; margin:auto;border:1px solid black; border-collapse:collapse;}
td {border:1px solid black;}
</style>
</head>
<body>
<h2>Ajax无刷新分页效果</h2>
<div id="result"></div>
</body>
</html>
<script type="text/javascript">
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
document.write(new Date()+"<br />");
</script>
page.class.php(Ajax无刷新分页工具类):<?php
class Page {
private $total; //数据表中总记录数
private $listRows; //每页显示行数
private $limit;
private $uri;
private $pageNum; //页数
private $config=array("header"=>"个记录", "prev"=>"上一页", "next"=>"下一页", "first"=>"首 页", "last"=>"尾 页");
private $listNum=8;
/*
* $total
* $listRows
*/
public function __construct($total, $listRows=10, $pa=""){
$this->total=$total;
$this->listRows=$listRows;
$this->uri=$this->getUri($pa);
$this->page=!empty($_GET["page"]) ? $_GET["page"] : 1;
$this->pageNum=ceil($this->total/$this->listRows);
$this->limit=$this->setLimit();
}
private function setLimit(){
return "Limit ".($this->page-1)*$this->listRows.", {$this->listRows}";
}
private function getUri($pa){
$url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], "?")?"":"?").$pa;
$parse=parse_url($url);
if(isset($parse["query"])){
parse_str($parse["query"],$params);
unset($params["page"]);
$url=$parse["path"]."?".http_build_query($params);
}
return $url;
}
function __get($args){
if($args=="limit")
return $this->limit;
else
return null;
}
private function start(){
if($this->total==0)
return 0;
else
return ($this->page-1)*$this->listRows+1;
}
private function end(){
return min($this->page*$this->listRows,$this->total);
}
private function first(){
$html = "";
if($this->page==1)
$html.="";
else
$html.=" <a href="javascript:showpage("{$this->uri}&page=1")">{$this->config["first"]}</a> ";
return $html;
}
private function prev(){
$html = "";
if($this->page==1)
$html.="";
else
$html.=" <a href="javascript:showpage("{$this->uri}&page=".($this->page-1)."")">{$this->config["prev"]}</a> ";
return $html;
}
private function pageList(){
$linkPage="";
$inum=floor($this->listNum/2);
for($i=$inum; $i>=1; $i--){
$page=$this->page-$i;
if($page<1)
continue;
//$linkPage.=" <a href="{$this->uri}&page={$page}">{$page}</a> ";
$linkPage.=" <a href="javascript:showpage("{$this->uri}&page={$page}")">{$page}</a> ";
}
$linkPage.=" {$this->page} ";
for($i=1; $i<=$inum; $i++){
$page=$this->page+$i;
if($page<=$this->pageNum){
//$linkPage.=" <a href="{$this->uri}&page={$page}">{$page}</a> ";
$linkPage.=" <a href="javascript:showpage("{$this->uri}&page={$page}")">{$page}</a> ";
}else{
break;
}
}
return $linkPage;
}
private function next(){
$html = "";
if($this->page==$this->pageNum)
$html.="";
else
$html.=" <a href="javascript:showpage("{$this->uri}&page=".($this->page+1)."")">{$this->config["next"]}</a> ";
return $html;
}
private function last(){
$html = "";
if($this->page==$this->pageNum)
$html.="";
else
$html.=" <a href="javascript:showpage("{$this->uri}&page=".($this->pageNum)."")">{$this->config["last"]}</a> ";
return $html;
}
private function goPage(){
return " <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>".$this->pageNum.")?".$this->pageNum.":this.value;showpage("".$this->uri."&page="+page+"")}" value="".$this->page."" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>".$this->pageNum.")?".$this->pageNum.":this.previousSibling.value;showpage("".$this->uri."&page="+page+"")"> ";
//return " <input type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>".$this->pageNum.")?".$this->pageNum.":this.value;location="".$this->uri."&page="+page+""}" value="".$this->page."" style="width:25px"><input type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>".$this->pageNum.")?".$this->pageNum.":this.previousSibling.value;location="".$this->uri."&page="+page+"""> ";
}
function fpage($display=array(0,1,2,3,4,5,6,7,8)){
$html[0]=" 共有<b>{$this->total}</b>{$this->config["header"]} ";
$html[1]=" 每页显示<b>".($this->end()-$this->start()+1)."</b>条,本页<b>{$this->start()}-{$this->end()}</b>条 ";
$html[2]=" <b>{$this->page}/{$this->pageNum}</b>页 ";
$html[3]=$this->first();
$html[4]=$this->prev();
$html[5]=$this->pageList();
$html[6]=$this->next();
$html[7]=$this->last();
$html[8]=$this->goPage();
$fpage="";
foreach($display as $index){
$fpage.=$html[$index];
}
return $fpage;
}
}
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
