关于论坛上问题`````

Dcboy 2003-09-14 09:09:46
一个论坛上一个帖子
有很多人回复

想用树型显示```请问如何实现

DATAGRID可以做到嘛????
...全文
41 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
pengcheng 2003-09-15
  • 打赏
  • 举报
回复
我头好晕啊。
delphizd 2003-09-15
  • 打赏
  • 举报
回复
我也晕,我觉得这种形式并不太好
Dcboy 2003-09-15
  • 打赏
  • 举报
回复
我晕了很久了``

就是asp.net
论坛的那种TREEVIEW
jackyhzzjcn 2003-09-14
  • 打赏
  • 举报
回复
可以用DataGrid和TREEVIEW结合 :)
Muzhu 2003-09-14
  • 打赏
  • 举报
回复
简要思路:动态修改xsl,再重新使用xsl转换xml。
treeview.xml
<?xml version='1.0' encoding="GB2312"?>
<?xml-stylesheet type="text/xsl" href="treeview.xsl"?>
<!DOCTYPE menus[
<!ELEMENT menus (menus,menuitem)*>
<!ELEMENT menuitem (#PCDATA)>
<!ATTLIST menus
id ID #REQUIRED
文本 CDATA #IMPLIED
展开 CDATA #IMPLIED
层 CDATA #IMPLIED>
]>
<menus id="id00" 层="0">
<menus id="id01" 文本="菜单一" 展开="true" 层="1">
<menuitem 文本="菜单项一"></menuitem>
</menus>
<menus id="id02" 文本="菜单二" 展开="false" 层="1">
<menuitem 文本="菜单项二"></menuitem>
<menuitem 文本="菜单项三"></menuitem>
</menus>
<menuitem 文本="菜单项四"></menuitem>
</menus>
treeview.xsl
<?xml version='1.0' encoding="GB2312"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<xsl:apply-templates select="menus"/>
</xsl:template>
<xsl:template match="menus">
<xsl:for-each select="child::*">
<xsl:apply-templates select="@文本"/>
</xsl:for-each>
</xsl:template>
<xsl:template match="@文本">
<xsl:if test="name(parent::*)='menus'">
<div onclick="myclick();">
<xsl:attribute name="id"><xsl:value-of select="parent::menus/@id"/></xsl:attribute>
<xsl:value-of select="."/>
</div>
<xsl:if test="parent::menus/@展开='true'">
<xsl:apply-templates select="parent::menus"/>
</xsl:if>
</xsl:if>
<xsl:if test="name(parent::*)='menuitem'">
<div><xsl:value-of select="."/></div>
</xsl:if>
</xsl:template>
</xsl:stylesheet>
003.htm
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<DIV id="xslTarget"></DIV>
<XML id="source" src="treeview.xml"></XML>
<XML id="style" src="treeview.xsl"></XML>
<SCRIPT LANGUAGE=jscript>
<!--
function myclick(){
var mynode = source.nodeFromID(window.event.srcElement.id);
alert(source.nodeFromID('id01'));
//mynode.setAttribute('展开','false');
xslTarget.innerHTML = source.transformNode(style.XMLDocument);
}
xslTarget.innerHTML = source.transformNode(style.XMLDocument);
//-->
</SCRIPT>
</body>
</html>
Muzhu 2003-09-14
  • 打赏
  • 举报
回复
将下面的代码复制到<head>~</head>里
<script language=JavaScript1.2>
scores = new Array(20);
var numTotal=0;
NS4 = (document.layers) ? 1 : 0;
IE4 = (document.all) ? 1 : 0;
ver4 = (NS4 || IE4) ? 1 : 0;

if (ver4) {
with (document) {
write("<STYLE TYPE='text/css'>");
if (NS4) {
write(".parent {position:absolute; visibility:visible}");
write(".child {position:absolute; visibility:visible}");
write(".regular {position:absolute; visibility:visible}")
}
else {
write(".child {display:none}")
}
write("</STYLE>");
}
}

function getIndex(el) {
ind = null;
for (i=0; i<document.layers.length; i++) {
whichEl = document.layers[i];
if (whichEl.id == el) {
ind = i;
break;
}
}
return ind;
}

function arrange() {
nextY = document.layers[firstInd].pageY +document.layers[firstInd].document.height;
for (i=firstInd+1; i<document.layers.length; i++) {
whichEl = document.layers[i];
if (whichEl.visibility != "hide") {
whichEl.pageY = nextY;
nextY += whichEl.document.height;
}
}
}

function initIt(){
if (!ver4) return;
if (NS4) {
for (i=0; i<document.layers.length; i++) {
whichEl = document.layers[i];
if (whichEl.id.indexOf("Child") != -1) whichEl.visibility = "hide";
}
arrange();
}
else {
divColl = document.all.tags("DIV");
for (i=0; i<divColl.length; i++) {
whichEl = divColl(i);
if (whichEl.className == "child") whichEl.style.display = "none";
}
}
}

function expandIt(el) {
if (!ver4) return;
if (IE4) {
whichEl1 = eval(el + "Child");
for(i=1;i<=numTotal;i++){
whichEl = eval(scores[i] + "Child");
if(whichEl!=whichEl1) {
whichEl.style.display = "none";
}
}
whichEl1 = eval(el + "Child");
if (whichEl1.style.display == "none") {
whichEl1.style.display = "block";
}
else {
whichEl1.style.display = "none";
}
}
else {
whichEl = eval("document." + el + "Child");
for(i=1;i<=numTotal;i++){
whichEl = eval("document." + scores[i] + "Child");
if(whichEl!=whichEl1) {
whichEl.visibility = "hide";
}
}
if (whichEl.visibility == "hide") {
whichEl.visibility = "show";
}
else {
whichEl.visibility = "hide";
}
arrange();
}
}
onload = initIt;
</script>
将下面的代码复制到<body>~</body>里
<div id=KB1Parent>
<a onClick="expandIt('KB1');return false" href="#"><img src="plus.gif" border=0>精品下载</a>
</div>
<div class=child id=KB1Child>
<a href="#"><img src="blank.gif" border=0>Dreamweaver 资源</a><br>
<a href="#"><img src="blank.gif" border=0>Fireworks 资源</a><br>
<a href="#"><img src="blank.gif" border=0>Flash 资源</a><br>
<a href="#"><img src="blank.gif" border=0>Photoshop 资源</a>
</div>
<div id=KB2Parent>
<a onClick="expandIt('KB2');return false" href="#"><img src="plus.gif" border=0>免费申请</a>
</div>
<div class=child id=KB2Child>
<a href="#"><img src="blank.gif" border=0>免费计数器申请</a><br>
<a href="#"><img src="blank.gif" border=0>免费留言板申请</a><br>
<a href="#"><img src="blank.gif" border=0>免费网上调查申请</a></div>
<div id=KB3Parent>
<a onClick="expandIt('KB3');return false" href="#"><img src="plus.gif" border=0>酷站源码</a>
</div>
<div class=child id=KB3Child>
<a href="#"><img src="blank.gif" border=0>脚本收集</a><br>
<a href="#"><img src="blank.gif" border=0>HTML特效</a><br>
<a href="#"><img src="blank.gif" border=0>ASP源程序下载</a><br>
<a href="#"><img src="blank.gif" border=0>XML方面</a><br>
</div>
<script>numTotal=3;scores[1]='KB1';scores[2]='KB2';scores[3]='KB3';</script>
制作要点:
1、每一个分类都需定义值:
  <div id=KB1Parent>                       // ID值为唯一的
  <a onClick="expandIt('KB1'); return false" href="#" >精品下载</a></div>  // 定义onclick属性
2、每一个分类下面的文件都需统一定义class及ID。
   <div class=child id=KB1Child>                  // ID值为唯一的
   <a href="#" >Dreamweaver 资源</div>
   <a href="#" >Dreamweaver 资源</div>
   </div>
3、在分类的下边有一 script 的定义:
  <script>numTotal=3;scores[1]='KB1';scores[2]='KB2';scores[3]='KB3';</script>
  如果要增加一个类,则需把 numTotal 增加数值,再加一个scores[N]='KBN',例:
  <script>numTotal=4;scores[1]='KB1';scores[2]='KB2';scores[3]='KB3';scores[4]='KB4';</script>


至此你就可以完成这个实例了,快去试试吧!
以上来自http://www.1studio.net/
以上来自http://www.1studio.net/
以上来自http://www.1studio.net/
以上来自http://www.1studio.net/
以上来自http://www.1studio.net/
以上来自http://www.1studio.net/
gxboy 2003-09-14
  • 打赏
  • 举报
回复
看动网的js
ArLi2003 2003-09-14
  • 打赏
  • 举报
回复
树型是指折叠吗?
要记得,要做出好的网页,就必须认清立场:

Javascript + HTML + ASP + C#

而ASPX 只是一堆没用的控件,要的只是它支持 C#
Dcboy 2003-09-14
  • 打赏
  • 举报
回复
跟动网得一样```
树猫 2003-09-14
  • 打赏
  • 举报
回复
可以啊
不过你的问题不太清楚啊,你到底想做什么,做成什么样子
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较急,部分功能还是没有完善的(但不会出错),我以后也会给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统会记录用户的选择,不用重复选择,也不会出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星会出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如表格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!
**课程特色**- **综合性论坛系统:** 这门课程是一门独特的Java Web实战课程,涵盖了论坛系统的各个功能模块,包括前台的公告信息展示、论坛板块、帖子排行、帖子发布、回帖、评论等,以及后台管理的系统各个模块的增删改查操作。学生将通过实际实现这些功能模块,获得全面的Java Web开发经验。- **前后端分离编程思想:** 课程强调采用前后端分离的编程思想,使用JSON进行数据交互,并结合Ajax来发送请求。这是当今市场需求的趋势,学生将学会如何在实际项目中应用这种技术,提前适应行业变革。- **完整代码提前发放和实践机会:** 课程的讲解方式强调引导学生动手复现代码的过程。会提前向学生提供课程代码,引导他们逐步实现每个功能模块,并解释背后的原理和技术细节。通过这种实践机会,学生将亲自动手,加深对所学技术的理解,并且有实际的项目作品可供展示。**课程收益**- **职业加成:** 课程内容与实际工作密切相关,学生通过练习实际项目,了解如何开发常见的论坛系统,为日后就业或项目开发提供宝贵的经验。- **思维提升:** 详细的讲解方式能够帮助学生提升解决问题的思维能力。学生将学会分析和理解各个功能模块的实现原理,培养独立思考和解决实际编程挑战的能力。- **实践经验:** 通过动手实现每个功能模块,学生将积累宝贵的实践经验。这有助于他们在日后的项目中更自信和高效地应用所学知识。总而言之,这门课程采用了独特的教学设计,注重实际项目的练习和深入剖析,培养学生的实践能力和解决问题的思维方式。通过参与课程,学生将获得实际工作中的职业加成和思维提升,同时积累宝贵的实践经验。这将为他们在就业市场中脱颖而出,打下坚实的基础。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧