树目录菜单的制作

菜单|菜单

制作方法:
第一步:嵌入代码。把下面这段代码复制到<head></head>标签之间。  

<style>
<!--
#foldheader{cursor:hand ; font-weight:bold ;
list-style-image:url(http://www.163design.net/a/y/fold.gif)}
#foldinglist{list-style-image:url(list.gif)}
//-->
</style>
<script language="JavaScript1.2">
<!--
/**
* Based on Folding Menu Tree
* Dynamic Drive (www.dynamicdrive.com)
* For full source code, installation instructions,
* 100's more DHTML scripts, and Terms Of
* Use, visit dynamicdrive.com
*
* Updated to support arbitrarily nested lists
* by Mark Quinn (mark@robocast.com) November 2nd 1998
*/

var head="display:''"
img1=new Image()
img1.src="http://www.163design.net/a/y/fold.gif"
img2=new Image()
img2.src="http://www.163design.net/a/y/open.gif"

function change(){
if(!document.all)
return
if (event.srcElement.id=="foldheader") {
var srcIndex = event.srcElement.sourceIndex
var nested = document.all[srcIndex+1]
if (nested.style.display=="none") {
nested.style.display=''
event.srcElement.style.listStyleImage="url(http://www.163design.net/a/y/open.gif)"
}
else {
nested.style.display="none"
event.srcElement.style.listStyleImage="url(http://www.163design.net/a/y/fold.gif)"
}
}
}

document.onclick=change

//-->
</script>

  

第二步:制作菜单。将代码插入到页面中要出现树形目录的地方。下面是一段代码范例:

<li id="foldheader">News
<ul id="foldinglist" style="display:none" style=&{head};>

CNN

ABC News

Vancouver Sun

<li id="foldheader">Games
<ul id="foldinglist" style="display:none" style=&{head};>

GameSpot

Happy Puppy

Game Center

<li id="foldheader">Software
<ul id="foldinglist" style="display:none" style=&{head};>

outer 1

outer 2
<li id="foldheader">Nested
<ul id="foldinglist" style="display:none" style=&{head};>

nested 1

nested 2

outer 3

outer 4

  

如果我们仔细分析一下的话不难发现制作列表的秘诀就是一个大的列表

<li id="foldheader">主目录名称
<ul id="foldinglist" style="display:none" style=&{head};>

<a href="对应地址 ">子目录名称

<a href="对应地址 ">子目录名称

<a href="对应地址 ">子目录名称

  

这样的好处是添加子菜单非常容易只要不断制作一些列表出来,并且加上连接就可以制作出下拉菜单了。如果要实现多级的子菜单也很容易只要将某项子菜单的id设置成为foldheader并且不加连接,后面的格式就如加灰部分一样和前面的代码是一样的,嵌套使用。

第三步:将一段代码复制到上面列表代码的下面。

<script language="JavaScript1.2">
<!--
/**
* Get cookie routine by Shelley Powers
* (shelley.powers@ne-dev.com)
*/
function get_cookie(Name) {
var search = Name + "="
var returnvalue = "";
if (document.cookie.length > 0) {
offset = document.cookie.indexOf(search)
// if cookie exists
if (offset != -1) {  
offset += search.length
// set index of beginning of value
end = document.cookie.indexOf(";", offset);
// set index of end of cookie value
if (end == -1) end = document.cookie.length;
returnvalue=unescape(document.cookie.substring(offset, end))
}
}
return returnvalue;
}

if (get_cookie(window.location.pathname) != ''){
var openresults=get_cookie(window.location.pathname).split(" ")
for (i=0 ; i < openresults.length ; i++){
foldinglist[openresults[i]].style.display=''
document.all[foldinglist[openresults[i]].sourceIndex -
1].style.listStyleImage="url(http://www.163design.net/a/y/open.gif)"
}
}

if (document.all){
var nodelength=foldinglist.length-1
var nodes=new Array(nodelength)
var openones=''
}

function check(){
for (i=0 ; i <= nodelength ; i++){
if (foldinglist[i].style.display=='')
openones=openones + " " + i
}
document.cookie=window.location.pathname+"="+openones
}

if (document.all)
document.body.onunload=check
//-->
</script>
  

  

第四步:将文件夹和菜单项前面的小图标图片文件复制到和网页文件同样的位置。命名规则:
关闭的文件夹:http://www.163design.net/a/y/fold.gif
打开的文件夹:http://www.163design.net/a/y/open.gif
菜单项目:list.gif

整个菜单就做好了。如果对于菜单文字不满意,可以修改第一步中的

<style>
<!--
#foldheader{cursor:hand ; font-weight:bold ;
list-style-image:url(http://www.163design.net/a/y/fold.gif)}
#foldinglist{list-style-image:url(list.gif)}
//-->
</style>  

这部分,当然前提是你要懂得一些css代码。

注:这个程序基本可以实现功能,但是有一个显然的缺点,就是目录的宽度没有被控制起来,手状的鼠标的范围太大 

时间: 2024-10-30 07:54:16

树目录菜单的制作的相关文章

Div+CSS+JS树型菜单,可刷新

css|js|菜单|刷新 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&

用PHP实现windows资源管理器风格的树型菜单

window|菜单 以下是一个风格类似windows资源管理器的树型菜单 将下面的脚本包含到你的页面中 另外需要从资源管理器中截取一些gif图片,祥见脚本中的注释 菜单结构文件的格式为: tree level|item text|item link|link target|last item in subtree 例如 .<b>Demo menu</b>|javascript: alert('This is the demo menu for TreeMenu 1.0'); ..&

javascript dtree: javascript树型菜单 dtree

js代码很简洁,但是实现了所有树形菜单应有的功能,安装和使用都很简单,特别是从数据库恢复成一棵树变得非常容易.下载包里自带一些常用图标,只需简单的操作,就可以实现看起来相当专业的树形菜单. 详细介绍应用dtree构建一个javascript树型菜单及其中参数配置说明 这几天写了个网站,用了一个javascript写的树型菜单,有网友问我要这个代码,很奇怪,了解一下,原来网上很多文章都在讨论js树型菜单,看了几个实例,发现确实没有我用的这个好,因此baidu了一下,略作整理,希望大家不要浪费无用功

位图菜单的制作

菜单 *******************************************************实用环境:pb6.5\pb70\pb80\pb90功    能:位图菜单的制作方    法:如下*******************************************************第一步,首先要建立一个menu对象,命名为:m_bitmap.设计格式有一个主菜单 File,下面有4个子菜单new\open ave\exit,如下: ----File----

PHP实例:用PHP实现windows风格的树型菜单

以下是一个风格类似windows资源管理器的树型菜单,将下面的脚本包含到你的页面中,另外需要从资源管理器中截取一些gif图片,祥见脚本中的注释,菜单结构文件的格式为: tree level|item text|item link|link target|last item in subtree 例如 以下为引用的内容: .<b>Demo menu</b>|javascript: alert('This is the demo menu for TreeMenu 1.0'); ..&

可刷新的Div+CSS+JS树型菜单

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Typ

JS+CSS实现类似QQ好友及黑名单效果的树型菜单_javascript技巧

本文实例讲述了JS+CSS实现类似QQ好友及黑名单效果的树型菜单.分享给大家供大家参考.具体如下: 今天介绍的这个菜单堪称极品啊,不过里面的有些图标丢失了,路径还留在那,真想使用的朋友自己制作两个折叠菜单的图标按路径传上去就行了,这个菜单是模仿QQ面板的菜单功能,很多朋友还是很喜欢这种功能的,没想到用这么少的JS代码也可实现 ,值得代签哦. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/js-css-qq-hy-hmd-style-menu-c

关于树目录删除后出现的问题

问题描述 现在想实现的是一个删除的功能首先下面这是一个给3级添4级节点的一个方法我现在要说的就是我在运行界面的时候他是先用这个方法把4级节点加到3级下面读出来显示在树目录上的然后我删除4级的时候它还会调用这个方法,可定是数据库没有了所以找不到会报这行错误找不到对应的直if(ds4.Tables[0].Rows[n2][1].ToString()==str3ID我想说的是怎样在运行时候调用这个方法和删除后调用这个方法避免上面的代码出现问题呢应该要写一个判断语句,如果有对应的实行下面的代码如果没有就

DIV+CSS构成的树型菜单

css|菜单 这是用DIV+CSS+JS构成的树型菜单,采用列表,符合WEB标准,在大多数WIN浏览器下,兼容性不错,xhtml见效果页,我现在做的是二个菜单,如果需要添加,可把<ul class="collapsed" id="submenuid2">......</ul>之间的内容加上去,"submenuid"加1,查看效果. CSS代码 body { margin: 0px; padding: 0; font: 12