樹目錄菜單的製作

來源:互聯網
上載者:User
菜單|菜單 製作方法:
第一步:內嵌程式碼。把下面這段代碼複製到<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代碼。



註:這個程式基本可以實現功能,但是有一個顯然的缺點,就是目錄的寬度沒有被控制起來,手狀的滑鼠的範圍太大 



相關文章

Cloud Intelligence Leading the Digital Future

Alibaba Cloud ACtivate Online Conference, Nov. 20th & 21st, 2019 (UTC+08)

Register Now >

Starter Package

SSD Cloud server and data transfer for only $2.50 a month

Get Started >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。