中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 不用Cookie的仿刷新二級高亮菜單
混亂的標(biāo)記語言XHTML2/HTML5 回到列表 在HTML中獲取正確的URL屬性值
 不用Cookie的仿刷新二級高亮菜單

作者:by0001 時間: 2009-07-29 文檔類型:原創(chuàng) 來自:藍色理想

第 1 頁 不用Cookie的仿刷新二級高亮菜單 [1]
第 2 頁 不用Cookie的仿刷新二級高亮菜單 [2]

行為層

因為要在行為層中控制菜單的三種狀態(tài),所以對于A鏈接標(biāo)簽,我們就不使用hover偽類來達到菜單的三種動態(tài)行為了,我們可以用onmouseover、onmouseout和onclick來模仿偽類的三種行為,這樣好便于js的動態(tài)調(diào)整。并且為了達到行為、樣式和結(jié)構(gòu)的三層分離,我們也不用在A標(biāo)簽的html中去加上動態(tài)的行為控制代碼,這不是一種良好的制作習(xí)慣。因此我們需要在頁面的加載函數(shù)上做點文章,這就需要使用到onload函數(shù),當(dāng)頁面一加載完后就動態(tài)綁定a標(biāo)簽的三種行為狀態(tài)。

在頁面一加載完成后,我們首先獲取當(dāng)前的頁面url字符串,再根據(jù)這個字符串和一二級菜單中的A標(biāo)簽的href地址進行對比,如果存在相同項,則高亮此菜單項的樣式。

詳細的注釋說明我都在下面的函數(shù)中一一標(biāo)注出來,在此就不一一細述了。關(guān)鍵函數(shù)代碼如下:

    //根據(jù)URL地址的參數(shù)或字符串高亮當(dāng)前菜單。
    function hightLightMenu(firstMenuID,twoMenuID){
    var strUrl,strHref,subNavs,strLast,strParentID,strSelfID,
parentID,selfID,strID;
    var Navs=document.getElementById(firstMenuID).getElementsByTagName("a");                        
    // 如果鏈接沒有參數(shù),或者URL鏈接中不存在我們要獲取的參數(shù),則返回數(shù)組中的序號
    if(location.href.indexOf("?")==-1){
        strUrl=location.href.substring(location.href.lastIndexOf("/")+1);//取得URL頁面名稱            
        //一級菜單高亮                    
        for (var i = 0; i < Navs.length; i++) {            
            //在IE6,IE7中strHref獲得的是全路徑,而在IE8和ff中獲得的是頁面名稱,為了兼容,需要將它的字符串進行拆分
            strHref=Navs[i].getAttribute("href").substring(Navs[i].getAttribute("href").lastIndexOf('/')+1);                    
            if(strUrl==strHref){
                //高亮當(dāng)前菜單項                        
                addClass(Navs[i],"cur");            
            }
            else{//如果是其它項,則綁定鼠標(biāo)兩態(tài)事件                            
                (function(i){
                    var obj=Navs[i];              
                    addEventHandler(obj,"mouseover",function(){overMe(obj)});
                    addEventHandler(obj,"mouseout",function(){outme(obj)});
                })(i)                             
            }                    
        }        
        //二級菜單高亮
        if (document.getElementById(twoMenuID) != null) {//判斷是否存在二級菜單    
            //有可能二級菜單不存在,如首頁只有一級菜單,所以當(dāng)菜單id存在時,則...            
            subNavs = document.getElementById("othermenu").getElementsByTagName('a');
            for (var n = 0; n < subNavs.length; n++) {
                hightlight(subNavs,n,0);//默認高亮第一個菜單項                
            }
        }
    }
    else{
        //如果url中帶有參數(shù)的頁面,則...            
        strLast = location.href.substring(location.href.indexOf("?")+1);    
        strParentID=strLast.substring(0,strLast.indexOf("&"));
        strSelfID=strLast.substring(strLast.indexOf("&")+1);    
        parentID=strParentID.substring(strParentID.indexOf("=")+1);//獲得第一個參數(shù),這是一級菜單的id
        selfID=strSelfID.substring(strSelfID.indexOf("=")+1);//獲得第二個參數(shù),這是二級菜單的id   
        
        //一級菜單高亮    
        for (var i = 0; i < Navs.length; i++) {
            hightlight(Navs,i,parentID);
        }
        //二級菜單高亮
        if (document.getElementById(twoMenuID) != null) {//判斷是否存在二級菜單            
            subNavs = document.getElementById(twoMenuID).getElementsByTagName('a');
            for (var n = 0; n < subNavs.length; n++) {
                strID=selfID - 1;                
                hightlight(subNavs,n,strID);                
            }
        }
    }        
    }
    //高亮函數(shù)
    function hightlight(elementArray,inumber,curMenuIndex){
    if (inumber == curMenuIndex) {        
        addClass(elementArray[inumber],"cur");//高亮當(dāng)前菜單樣式
    }
    else {
        (function(inumber){
            var obj = elementArray[inumber];
            addEventHandler(obj, "mouseover", function(){overMe(obj)});//增加鼠標(biāo)移上去時的事件
            addEventHandler(obj, "mouseout", function(){outme(obj)});//增加鼠標(biāo)移走時的事件
        })(inumber)
    }    
    }

經(jīng)過如上一番設(shè)置,一個通用、兼容的高亮函數(shù)就誕生了,我們看看它的效果截圖:

本案例的高亮函數(shù)在如下瀏覽器中測試通過:

IE5.5,IE6,IE7,IE8,FF3,TT,Maxthon,Chrome,Safari4.0,opera

因為子頁面較多,請下載本案例打包文件到本地測試:下載Demo

原文:http://www.cnblogs.com/binyong/archive/2009/07/27/1531441.html

經(jīng)典論壇交流
http://bbs.blueidea.com/thread-2941335-1-1.html

本文鏈接:http://m.95time.cn/tech/web/2009/6915.asp 

出處:藍色理想
責(zé)任編輯:bluehearts

上一頁 不用Cookie的仿刷新二級高亮菜單 [1] 下一頁

◎進入論壇網(wǎng)頁制作WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。

相關(guān)文章
瀏覽器 cookie 限制
使用Flash讀取COOKIE
作者文章 更多作者文章
無hack并支持透明圓角框九宮格
九宮格應(yīng)用案例:極酷網(wǎng)頁播放器
三層分離的完美九宮格
牢不可破的九宮格布局
九宮格基本布局
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大福“敬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:2/21個記錄/頁 轉(zhuǎn)到 頁 共2個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2