高仿CSDN社区树形图

一直感觉CSDN社区的树形结构特别的人性化,直观化。最近做系统的时候需要用到这个树形结构,于是模仿CSDN的树形结构做了一个自己的树形结构,将实现过程记录如下,希望对读者有用。

工欲善其事必先利其器,要模仿一个经典的树形结构就应该参照人家是怎么实现的,这里用到了firebug插件,在firefox中查看了CSDN的树形结构的组成,发现其实树形结构就是一个个的DIV借助img以及背景图片拼凑而成,整理了一下思路发现其实要想达到CSDN的效果也不是很困难。

让我们一步一步的分析

1、首先把用到的图片下载下来,一共15个图片,利用firebug工具可以很轻松的把图片下载(另存为)下来。

2、以上这些图片都是在CSS文件中作为背景图片出现的,其他地方以空白图片填充。

3、然后分析树形结构的组成,首先有一个根目录,然后每个根目录下面有其子目录,也就是说每个子目录开始的时候是隐藏的只有当鼠标点击展开的时候才会显示,在此过程中节点图标以及文件夹图标会变化。

javascript代码:

[javascript] view plain copy print ?
  1.         <script language="JavaScript"> 
  2. function display(id) { 
  3.      eval("var div=div"+id); 
  4.      eval("var img=img"+id); 
  5.      eval("var im=im"+id); 
  6.      div.style.display=div.style.display=="block"?"none":"block"; 
  7.      img.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif"; 
  8.      im.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folderopen.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif"; 
  9.      img.alt=div.style.display=="block"?"关闭":"展开"; 
  10. </script> 
		<script language="JavaScript">function display(id) {	 eval("var div=div"+id);	 eval("var img=img"+id);	 eval("var im=im"+id);	 div.style.display=div.style.display=="block"?"none":"block";	 img.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif";	 im.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folderopen.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif";	 img.alt=div.style.display=="block"?"关闭":"展开";}</script>


4、当点击展开标签的时候进行判断如果为缩略图片则转变为展开图片并且将隐藏的内容显示,以至于达到资源管理器的效果。

全部实现代码:

  1. <html> 
  2.     <head> 
  3.         <meta http-equiv="Content-Type" content="text/html; charset=GB18030"> 
  4.      
  5.  
  6.  
  7.         <script language="JavaScript"> 
  8. function display(id) { 
  9.      eval("var div=div"+id); 
  10.      eval("var img=img"+id); 
  11.      eval("var im=im"+id); 
  12.      div.style.display=div.style.display=="block"?"none":"block"; 
  13.      img.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif"; 
  14.      im.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folderopen.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif"; 
  15.      img.alt=div.style.display=="block"?"关闭":"展开"; 
  16. </script> 
  17.     </head> 
  18.     <body class="body1" style="background-color :#E5E5E5"> 
  19.     <div id="title" ></div> 
  20.         <table> 
  21.             <tr> 
  22.                 <td valign="top" nowrap="nowrap"> 
  23.                     <div> 
  24.                         <img alt="展开" style="cursor:hand;" onClick="display('1');" 
  25.                             id="img1" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif"> 
  26.                         <img id="im1" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif"> 
  27.                         <a> 根目录</a> 
  28.                         <div style="display:none;" id="div1"> 
  29.                             <div style="background-image:http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line1.gif"> 
  30.                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif" > 
  31.                                 <img alt="展开" style="cursor:hand;" onClick="display('2');" 
  32.                                     id="img2" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif"> 
  33.                                 <img id="im2" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif"> 
  34.                                 <a>二级目录</a>  
  35.                                <div style="display:none;" id="div2"> 
  36.                                     <div> 
  37.                                         <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  38.                                         <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  39.                                         <img alt="展开" style="cursor:hand;" onClick="display('3');" 
  40.                                             id="img3" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif"> 
  41.                                         <img id="im3" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif"> 
  42.                                         <a>三级目录</a> 
  43.                                         <div style="display:none;" id="div3"> 
  44.                                             <div> 
  45.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  46.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  47.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  48.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif"> 
  49.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif"> 
  50.                                                 <a>题目一</a> 
  51.                                             <div> 
  52.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  53.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  54.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  55.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif"> 
  56.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif"> 
  57.                                                  
  58.                                                 <a>题目二</a> 
  59.                                             </div> 
  60.                                             <div> 
  61.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  62.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  63.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  64.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif"> 
  65.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif"> 
  66.                                                 <a>题目三</a> 
  67.                                              </div> 
  68.                                              <div> 
  69.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  70.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  71.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif"> 
  72.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus2.gif"> 
  73.                                                 <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif"> 
  74.                                                 <a>题目四</a> 
  75.                                              </div> 
  76.                                             </div> 
  77.                                         </div> 
  78.                                     </div>                    
  79.                                 </div>                                 
  80.                             </div> 
  81.                         </div> 
  82.                     </div> 
  83.                 </td> 
  84.             </tr> 
  85.         </table> 
  86.     </body> 
  87. </html> 
<html>	<head>		<meta http-equiv="Content-Type" content="text/html; charset=GB18030">			<script language="JavaScript">function display(id) {	 eval("var div=div"+id);	 eval("var img=img"+id);	 eval("var im=im"+id);	 div.style.display=div.style.display=="block"?"none":"block";	 img.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif";	 im.src=div.style.display=="block"?"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folderopen.gif":"http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif";	 img.alt=div.style.display=="block"?"关闭":"展开";}</script>	</head>	<body class="body1" style="background-color :#E5E5E5">    <div id="title" ></div>		<table>			<tr>				<td valign="top" nowrap="nowrap">					<div>						<img alt="展开" style="cursor:hand;" onClick="display('1');"							id="img1" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif">						<img id="im1" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif">						<a> 根目录</a>						<div style="display:none;" id="div1">							<div style="background-image:http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line1.gif">								<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif" >								<img alt="展开" style="cursor:hand;" onClick="display('2');"									id="img2" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif">								<img id="im2" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif">								<a>二级目录</a>	                               <div style="display:none;" id="div2">									<div>										<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">										<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">										<img alt="展开" style="cursor:hand;" onClick="display('3');"											id="img3" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_plus1.gif">										<img id="im3" src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/folder.gif">										<a>三级目录</a>										<div style="display:none;" id="div3">											<div>												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif">												<a>题目一</a>                                            <div>                                                <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif">                                                                                                <a>题目二</a>                                            </div>                                            <div>                                                <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus1.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif">                                                <a>题目三</a>                                             </div>                                             <div>                                                <img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_line4.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/_minus2.gif">												<img src="http://bbs.csdn.net/ui/scripts/System/_resource/MzTreeView/file.gif">                                                <a>题目四</a>                                             </div>											</div>										</div>									</div>              	   								</div>                                                            </div>						</div>					</div>				</td>			</tr>		</table>	</body></html>


实现效果如下:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值