分享
 
 
 

类似 MSDN CSDN 左边导航树效果的实现! [JavaScript + ASP]

王朝html/css/js·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

MSDN 和CSDN 左边导航树的效果都是在点击父节点时,再发出请求填充其子节点!好像网页只刷新部分! JavaScript + [ASP + Access] 实现

源程序下载: http://www.triaton.com.cn/Private/Zip/Tree.zip

<!-- Tree.asp -->

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

<TITLE> New Document </TITLE>

<META NAME="Generator" CONTENT="EditPlus">

<META NAME="Author" CONTENT="">

<META NAME="Keywords" CONTENT="">

<META NAME="Description" CONTENT="">

</HEAD>

<BODY>

<iframe width="100%" height="30" id="hiddenframe"></iframe>

<script>

function ExpandNode(ParentNode,ParentId){

var NodeX = eval(ParentNode.id + '_0');

if (NodeX.style.display == 'none')

{

NodeX.style.display="block";

if (NodeX.loaded == 'no')

{

document.frames['hiddenframe'].location.replace("http://localhost/dvbbs/subtree.asp?PID=" + ParentId + "&PNode=" + ParentNode.id);

NodeX.loaded = 'yes';

}

}

else

{

NodeX.style.display='none';

}

}

</script>

<CENTER>

<TABLE border="1" width="20%" height="60%">

<TR>

<TD>

<DIV style="OVERFLOW: auto;WIDTH: 100%;HEIGHT:100%">

<TABLE width =300%>

<TR>

<TD>

<%

dim adoConnection

set adoConnection = Server.CreateObject("ADODB.Connection")

'adoConnection.Open "Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=Test;Data Source=TRIATON\PSQL2KE"

adoConnection.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.mappath("/dvbbs") & "\Tree.mdb;Persist Security Info=False"

dim adoRecordset

set adoRecordset = Server.CreateObject("ADODB.Recordset")

adoRecordset.Open "select *,(select count(*) from tree where parentid = T.id) as children from tree T where rootid = id ",adoConnection

dim i

i=0

do until adoRecordset.eof

%>

<div id='Node_<% = i %>'>

<a href='#'

<% if adoRecordset.Fields.item("Children").value >0 then %>

onClick='ExpandNode(Node_<% = i %>,<% =adoRecordset.Fields.item("id").value%>)'>+</a>

<% else %>

>-</a>

<% end if%>

<a href='#' onDblClick='ExpandNode(Node_<% = i %>,<% =adoRecordset.Fields.item("id").value%>)'><% =adoRecordset.Fields.item("remark").value%></a>

</div>

<div id='Node_<% = i %>_0' style='display: none' loaded='no'>

&nbsp;&nbsp;正在加载 ...

</div>

<% i=i+1

adoRecordset.MoveNext

loop

adoRecordset.close

set adoRecordset = nothing

adoConnection.close

set adoConnection = nothing

%>

</TD>

</TR>

</TABLE>

</DIV>

</TD>

</TR>

</TABLE>

</CENTER>

</BODY>

</HTML>

<!-- SubTree.asp -->

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

<TITLE> New Document </TITLE>

<META NAME="Generator" CONTENT="EditPlus">

<META NAME="Author" CONTENT="">

<META NAME="Keywords" CONTENT="">

<META NAME="Description" CONTENT="">

</HEAD>

<BODY>

<%

dim parentid

parentid = request.querystring("PID")

parentnode = request.querystring("Parentnode")

dim adoConnection

set adoConnection = Server.CreateObject("ADODB.Connection")

' adoConnection.Open "Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=Test;Data Source=TRIATON\PSQL2KE"

adoConnection.Open "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.mappath("/dvbbs") & "\Tree.mdb;Persist Security Info=False"

dim adoRecordset

set adoRecordset = Server.CreateObject("ADODB.Recordset")

adoRecordset.Open "select *,(select count(*) from tree where parentid =T.id ) as Children from tree T where parentid = " & parentid ,adoConnection

response.write adoRecordset.source

dim i

Dim SHTML

dim parentnode

parentnode = request.querystring("Pnode")

dim j

j= len(parentnode) - len(replace(parentnode,"_",""))

dim nSpace

for i=0 to j - 1

nSpace = nSpace + "&nbsp;&nbsp;"

next

i=0

do until adoRecordset.eof

shtml = shtml _

& "<div id='" & parentnode & "_" & i + 1 & "'>" & nSpace _

& "<a href='#'"

if adoRecordset.Fields.item("Children").value >0 then

shtml = shtml & " onClick='ExpandNode(" & parentnode & "_" & i + 1 & "," & adoRecordset.Fields.item("id").value & ")'>+"

else

shtml = shtml & ">-"

end if

shtml = shtml & "</a>\n" & "<a href='#'"

if adoRecordset.Fields.item("Children").value >0 then

shtml = shtml & "onDblClick='ExpandNode(" & parentnode & "_" & i + 1 & "," & adoRecordset.Fields.item("id").value & ")'"

end if

shtml = shtml & ">" & adoRecordset.Fields.item("id").value & ": " & adoRecordset.Fields.item("remark").value & "</a></div>"

if adoRecordset.Fields.item("Children").value >0 then

shtml = shtml & "<div id='" & parentnode & "_" & i + 1 & "_0' style='display: none' loaded='no'>" & nSpace & "&nbsp;&nbsp;正在加载 ...</div>"

end if

i=i+1

adoRecordset.MoveNext

loop

adoRecordset.close

set adoRecordset = nothing

adoConnection.close

set adoConnection = nothing

'response.write shtml

%>

<script>

var x = eval('parent.' + '<% =request.querystring("Pnode") & "_0"%>' ) ;

x.innerHTML="<% =shtml %>";

</script>

</BODY>

</HTML>

表结构:

Tree(id,parentid,remark)

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有