php 無限級數(shù)據(jù)JSON格式及JS解析
更新時間:2010年07月17日 23:57:45 作者:
公司要做個Flash效果的頁面,需要個無限級樹,顯示用戶邀請的好友及其下線,由此就構(gòu)成了無限級的關(guān)系,可能下線有無限多。
Flash需要JSON格式的數(shù)據(jù),于是,就有了如下代碼:(PHP實現(xiàn),C#類似,JSON庫自己去下吧~~)
//--查詢用戶下線信息,返回JSON,用于flash
if(!empty($_GET['action'])&&!empty($_GET['invite'])){
//固定參數(shù)請求才會返回信息
if($_GET['action']=='getinfo'&&$_GET['invite']==1){
//數(shù)據(jù)實體,一個實體類
class UcInvite{
//---顯示用的數(shù)據(jù)信息
public $fuid; //用戶id
public $funame; //用戶名
public $furl; //用戶空間地址
//---顯示用的數(shù)據(jù)信息
public $fchilds; //子類集合
}
$invitecount = 0; //總數(shù)量,用于記錄全部下線數(shù)量
//遞歸實現(xiàn)方法
function GetShowTreeInvite($uid){
global $_SGLOBAL,$invitecount;
//組織sql語句并查詢,表中fuid是下線的id,uid是父id,fusername是用戶名字
$inv_sql = "select fuid,fusername from ".tname("invite")." where uid = ".$uid;
$inv_query = $_SGLOBAL['db']->query($inv_sql);
//下表及返回數(shù)組
$index = 0;
$inviteTree = Array();
$invitezcount = 0; //每個子類下的數(shù)量
//循環(huán)添加信息到數(shù)組
while($v = $_SGLOBAL['db']->fetch_array($inv_query)){
$ui = new UcInvite();
$ui->fuid = $v['fuid'];
$ui->funame = $v['fusername'];
$ui->furl = "/home/space.php?uid=".$v['fuid'];
//調(diào)用自己,遞歸查詢子類信息
$ui->fchilds=GetShowTreeInvite($v['fuid']);
//插入返回的數(shù)組中
$inviteTree[$index]=$ui;
$index++;
$invitecount++;
$invitezcount++;
}
//記錄當(dāng)前下線的下線數(shù)量
$inviteTree['invitezcount'] = $invitezcount;
//返回數(shù)組信息
return $inviteTree;
}
$fuid = empty($_GET['fuid'])?$space[uid]:$_GET['fuid'];
//根據(jù)當(dāng)前登錄用戶ID查詢信息,并返回一個集合
$inviteTree = GetShowTreeInvite($fuid);
//記錄總下線數(shù)
$inviteTree['invitecount'] = $invitecount;
//引入json庫,這里用的是Services_JSON
//因為并不確定服務(wù)器都是PHP5.2以上版本,所以沒有用自帶的JSON函數(shù)
require_once('../plugins/JSON/JSON.php');
//json輸出
$json = new Services_JSON();
echo $json->encode($inviteTree);
exit;
}else{
echo '請求參數(shù)錯誤!';
exit;
}
}
//--查詢用戶下線信息,返回JSON,用于flash
以上代碼返回一個JSON字符串,如:
{'0':{'fuid':'950','funame':'郭梓原','furl':'/home/space.php?uid=950','fchilds':{'invitezcount':0}},'invitezcount':1,'invitecount':1}
這里只查詢了一個
接下來用JS進(jìn)行以下解析:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script type="text/javascript">
//fuid 用戶ID
//funame 用戶名稱
//furl 用戶主頁地址
//invitezcount 每個用戶的子類數(shù)量
//invitecount 該用戶的所有下級數(shù)量
var str = "";
function GetShow(obj,qi,index){
for (var one in obj)
{
for(var key in obj[one])
{
index++;
if(key=="fchilds"&&obj[one][key]['invitezcount']!=0){
var aqi = qi;
if(index>1)aqi+=" "
GetShow(obj[one][key],aqi,index)
}
if(key != 'fchilds'){
if(key=="fuid"){
str += qi+key+"="+obj[one][key] + ",";
}else{
str += key+"="+obj[one][key] + ",";
}
if(key == "furl"){
str+="<br/>";
}
}
}
if(one=="invitezcount"||one=="invitecount"){
str+=qi+one+"="+obj[one]+"<br/>";
}
}
}
//固定參數(shù)do=charadegarden&action=getinfo&invite=1,fuid為測試時使用,不填寫將調(diào)用系統(tǒng)當(dāng)前登錄的用戶ID
var url = 'http://localhost/home/space.php?do=charadegarden&action=getinfo&invite=1&fuid=344';
$.get(url,function(html){
//獲得json并轉(zhuǎn)為對象
if(html){
var obj = eval("["+html+"]");
GetShow(obj[0],"",1)
document.write(str);
document.write("<br/><br/><br/><br/>");
document.write("<b>JSON格式:</b><br/>");
document.write(html);
}
});
</script>
復(fù)制代碼 代碼如下:
//--查詢用戶下線信息,返回JSON,用于flash
if(!empty($_GET['action'])&&!empty($_GET['invite'])){
//固定參數(shù)請求才會返回信息
if($_GET['action']=='getinfo'&&$_GET['invite']==1){
//數(shù)據(jù)實體,一個實體類
class UcInvite{
//---顯示用的數(shù)據(jù)信息
public $fuid; //用戶id
public $funame; //用戶名
public $furl; //用戶空間地址
//---顯示用的數(shù)據(jù)信息
public $fchilds; //子類集合
}
$invitecount = 0; //總數(shù)量,用于記錄全部下線數(shù)量
//遞歸實現(xiàn)方法
function GetShowTreeInvite($uid){
global $_SGLOBAL,$invitecount;
//組織sql語句并查詢,表中fuid是下線的id,uid是父id,fusername是用戶名字
$inv_sql = "select fuid,fusername from ".tname("invite")." where uid = ".$uid;
$inv_query = $_SGLOBAL['db']->query($inv_sql);
//下表及返回數(shù)組
$index = 0;
$inviteTree = Array();
$invitezcount = 0; //每個子類下的數(shù)量
//循環(huán)添加信息到數(shù)組
while($v = $_SGLOBAL['db']->fetch_array($inv_query)){
$ui = new UcInvite();
$ui->fuid = $v['fuid'];
$ui->funame = $v['fusername'];
$ui->furl = "/home/space.php?uid=".$v['fuid'];
//調(diào)用自己,遞歸查詢子類信息
$ui->fchilds=GetShowTreeInvite($v['fuid']);
//插入返回的數(shù)組中
$inviteTree[$index]=$ui;
$index++;
$invitecount++;
$invitezcount++;
}
//記錄當(dāng)前下線的下線數(shù)量
$inviteTree['invitezcount'] = $invitezcount;
//返回數(shù)組信息
return $inviteTree;
}
$fuid = empty($_GET['fuid'])?$space[uid]:$_GET['fuid'];
//根據(jù)當(dāng)前登錄用戶ID查詢信息,并返回一個集合
$inviteTree = GetShowTreeInvite($fuid);
//記錄總下線數(shù)
$inviteTree['invitecount'] = $invitecount;
//引入json庫,這里用的是Services_JSON
//因為并不確定服務(wù)器都是PHP5.2以上版本,所以沒有用自帶的JSON函數(shù)
require_once('../plugins/JSON/JSON.php');
//json輸出
$json = new Services_JSON();
echo $json->encode($inviteTree);
exit;
}else{
echo '請求參數(shù)錯誤!';
exit;
}
}
//--查詢用戶下線信息,返回JSON,用于flash
以上代碼返回一個JSON字符串,如:
{'0':{'fuid':'950','funame':'郭梓原','furl':'/home/space.php?uid=950','fchilds':{'invitezcount':0}},'invitezcount':1,'invitecount':1}
這里只查詢了一個
接下來用JS進(jìn)行以下解析:
復(fù)制代碼 代碼如下:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script type="text/javascript">
//fuid 用戶ID
//funame 用戶名稱
//furl 用戶主頁地址
//invitezcount 每個用戶的子類數(shù)量
//invitecount 該用戶的所有下級數(shù)量
var str = "";
function GetShow(obj,qi,index){
for (var one in obj)
{
for(var key in obj[one])
{
index++;
if(key=="fchilds"&&obj[one][key]['invitezcount']!=0){
var aqi = qi;
if(index>1)aqi+=" "
GetShow(obj[one][key],aqi,index)
}
if(key != 'fchilds'){
if(key=="fuid"){
str += qi+key+"="+obj[one][key] + ",";
}else{
str += key+"="+obj[one][key] + ",";
}
if(key == "furl"){
str+="<br/>";
}
}
}
if(one=="invitezcount"||one=="invitecount"){
str+=qi+one+"="+obj[one]+"<br/>";
}
}
}
//固定參數(shù)do=charadegarden&action=getinfo&invite=1,fuid為測試時使用,不填寫將調(diào)用系統(tǒng)當(dāng)前登錄的用戶ID
var url = 'http://localhost/home/space.php?do=charadegarden&action=getinfo&invite=1&fuid=344';
$.get(url,function(html){
//獲得json并轉(zhuǎn)為對象
if(html){
var obj = eval("["+html+"]");
GetShow(obj[0],"",1)
document.write(str);
document.write("<br/><br/><br/><br/>");
document.write("<b>JSON格式:</b><br/>");
document.write(html);
}
});
</script>
這樣,兩個無限級的操作就完成了,結(jié)果截圖:
珍惜勞動成果,雖說內(nèi)容不多,可是也是一個一個字打上的,轉(zhuǎn)載請注明!!關(guān)注愛拼可樂吧
您可能感興趣的文章:
- 基于BootStrap Metronic開發(fā)框架經(jīng)驗小結(jié)【二】列表分頁處理和插件JSTree的使用
- jsTree 基于JQuery的排序節(jié)點 Bug
- jquery下jstree簡單應(yīng)用 - v1.0
- jquery.jstree 增加節(jié)點的雙擊事件代碼
- 基于jsTree的無限級樹JSON數(shù)據(jù)的轉(zhuǎn)換代碼
- JQery jstree 大數(shù)據(jù)量問題解決方法
- jsTree樹控件(基于jQuery, 超強(qiáng)悍)[推薦]
- 關(guān)于無限分級(ASP+數(shù)據(jù)庫+JS)的實現(xiàn)代碼
- js實現(xiàn)無限級樹形導(dǎo)航列表效果代碼
- json+jQuery實現(xiàn)的無限級樹形菜單效果代碼
- javascript實現(xiàn)無限級select聯(lián)動菜單
- 基于jquery的無限級聯(lián)下拉框js插件
- js無限級折疊菜單精簡版
- PHP+JS無限級可伸縮菜單詳解(簡單易懂)
- jstree創(chuàng)建無限分級樹的方法【基于ajax動態(tài)創(chuàng)建子節(jié)點】
相關(guān)文章
Laravel框架控制器的middleware中間件用法分析
這篇文章主要介紹了Laravel框架控制器的middleware中間件用法,結(jié)合具體案例形式分析了Laravel框架控制器的middleware中間件相關(guān)使用步驟、操作技巧與注意事項,需要的朋友可以參考下2019-09-09php處理靜態(tài)頁面:頁面設(shè)置緩存時間實例
本篇文章主要介紹了php處理靜態(tài)頁面:頁面設(shè)置緩存時間實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-06-06