天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

利用js跨頁面保存變量做菜單的方法

最近公司在做一個項目,其中一塊頭部的菜單導(dǎo)航區(qū),要求實現(xiàn)進入相關(guān)頁面后上面的導(dǎo)航菜單圖片也需變換.而這個對于靜態(tài)頁面或者用框架或iframe的來說是很容易實現(xiàn)的.而我們是利用include來包含進的這個top.ASP.雖然可以在那個圖片菜單上定義onclick的動作屬性.但是只要一跳轉(zhuǎn)頁面,則這個onclick動作就沒用了.因為top.ASP被重新加載了.如果要解決這個問題,只能是在頁面加載時能讀取一個全局的變量,相對于瀏覽器的全局變量,通過這個變量的值來判斷應(yīng)該如何顯示這個導(dǎo)航菜單.于是也便有了本文.

我想到的解決方法有兩種:

1.利用cookies或session,在每個頁面加載時寫一個cookies或session變量,這個看似能很好的解決問題.但是卻出現(xiàn)了一個問題.那就是如果用戶禁止了cookies,則這個效果將無法實現(xiàn),永遠只是顯示默認效果.所以我放棄這種做法

2.利用history或navigator來建立這么一個相對于瀏覽器的變量.只要我瀏覽器沒關(guān),則這個變量就會持續(xù)存在.這樣就達到了我們想要的效果.我也是用這種方法來解決的.下面是具體實現(xiàn)部分.

 

<script type="text/JavaScript">
<!--
 function foc(){
 document.getElementById("searchkey").focus();
 }   //這是做搜索時一個函數(shù)與本文無關(guān)

 function init(){  //初始化函數(shù)
  if (history.dmenu){}else
  {
   history.dmenu=1;
  }

//如果history.dmenu沒有定義則設(shè)置為1即顯示首頁按扭的效果
  switch(history.dmenu){
   case 1:
    {
    //alert(history.dmenu);
    document.getElementById("d_id1").src="/images/anB1.gif";
    document.getElementById("d_id2").src="/images/anB2.gif";
    document.getElementById("d_id3").src="/images/anB3.gif";
    document.getElementById("d_id4").src="/images/anB4.gif";
    document.getElementById("d_id5").src="/images/anB5.gif";
    document.getElementById("d_id6").src="/images/anB6.gif";
    break;}
    case 2:
    {
    //alert(history.dmenu);
    document.getElementById("d_id1").src="/images/anB11.gif";
    document.getElementById("d_id2").src="/images/anB22.gif";
    document.getElementById("d_id3").src="/images/anB3.gif";
    document.getElementById("d_id4").src="/images/anB4.gif";
    document.getElementById("d_id5").src="/images/anB5.gif";
    document.getElementById("d_id6").src="/images/anB6.gif";
    break;
    }
    case 3:
    {
    document.getElementById("d_id1").src="/images/anB11.gif";
    document.getElementById("d_id2").src="/images/anB2.gif";
    document.getElementById("d_id3").src="/images/anB33.gif";
    document.getElementById("d_id4").src="/images/anB4.gif";
    document.getElementById("d_id5").src="/images/anB5.gif";
    document.getElementById("d_id6").src="/images/anB6.gif";
    break;
    }
    case 4:
    {
    document.getElementById("d_id1").src="/images/anB11.gif";
    document.getElementById("d_id2").src="/images/anB2.gif";
    document.getElementById("d_id3").src="/images/anB3.gif";
    document.getElementById("d_id4").src="/images/anB44.gif";
    document.getElementById("d_id5").src="/images/anB5.gif";
    document.getElementById("d_id6").src="/images/anB6.gif";
    break;
    }
    case 5:
    {
    document.getElementById("d_id1").src="/images/anB11.gif";
    document.getElementById("d_id2").src="/images/anB2.gif";
    document.getElementById("d_id3").src="/images/anB3.gif";
    document.getElementById("d_id4").src="/images/anB4.gif";
    document.getElementById("d_id5").src="/images/anB55.gif";
    document.getElementById("d_id6").src="/images/anB6.gif";
    break;
    }
    case 6:
    {
    document.getElementById("d_id1").src="/images/anB11.gif";
    document.getElementById("d_id2").src="/images/anB2.gif";
    document.getElementById("d_id3").src="/images/anB3.gif";
    document.getElementById("d_id4").src="/images/anB4.gif";
    document.getElementById("d_id5").src="/images/anB5.gif";
    document.getElementById("d_id6").src="/images/anB66.gif";
    break;
    }
  }
 }
 //上面是具體的判斷那個變量然后據(jù)變量的值來進行圖片的變換從而達到我們要的效果.


 function menushow(d_id){

  switch(d_id){
   case 1:
    history.dmenu=1;
    break;
   case 2:
    history.dmenu=2;
    break;
   case 3:
    history.dmenu=3;
    break;
   case 4:
    history.dmenu=4;
    break;
   case 5:
    history.dmenu=5;
    break;
   case 6:
    history.dmenu=6;
    break;
  }
 }
 //按下相關(guān)圖片按鈕后設(shè)置history.dmenu為相應(yīng)的值從而在頁面加載時能根據(jù)這個值來進行圖片的變換

//-->
</script>
<table width="960" border="0" align="center" cellpadding="0" cellspacing="0">
  <tr>
    <td height="57" colspan="4"><table width="100%" border="0" cellpadding="0" cellspacing="0">
      <tr>
        <td width="394" height="57" rowspan="2"><img src="/images/LOGO.gif" width="394" height="57" /></td>
        <td width="134" height="43"> </td>
        <td width="129" align="right" valign="middle"><a href="#"><img src="/images/anA1.gif" width="114" height="26" border="0" /></a></td>
        <td width="97" align="right" valign="middle"><a href="#"><img src="/images/anA2.gif" width="78" height="26" border="0" /></a></td>
        <td width="100" align="right" valign="middle"><strong><a href="#"><img src="/images/anA3.gif" width="75" height="26" border="0" /></a></strong></td>
        <td width="92" align="right" valign="middle"><a href="#"><img src="/images/anA4.gif" width="70" height="26" border="0" /></a></td>
        <td width="14" align="right" valign="middle"> </td>
      </tr>
      <tr>
        <td colspan="6"> </td>
      </tr>
    </table></td>
  </tr>
  <tr>
    <td colspan="4"><table width="100%" border="0" cellpadding="0" cellspacing="0">
      <tr>
        <td width="104"><a href="/"><img src="/images/anB1.gif" name="d_id1" width="103" height="28" border="0" id="d_id1" onClick="menushow(1)"/></a></td>
        <td width="104" height="28"><a href="/order/"><img src="/images/anB2.gif" name="d_id2" width="104" height="28" / border="0" id="d_id2" onClick="menushow(2)"></a></td>
        <td width="104"><a href="/news/"><img src="/images/anB3.gif" name="d_id3" width="104" height="28" border="0" id="d_id3" onClick="menushow(3)"/></a></td>
          <td width="104"><a href="/law/"><img src="/images/anB6.gif" name="d_id4" width="104" height="28" border="0" id="d_id4"  onClick="menushow(4)"/></a></td>
  <td width="104"><a href="/exhibit/"><img src="/images/anB4.gif" name="d_id5" width="104" height="28" border="0" id="d_id5" onClick="menushow(5)"/></a></td>
        <td width="104"><a href="/company/"><img src="/images/anB5.gif" name="d_id6" width="104" height="28" border="0" id="d_id6" onClick="menushow(6)"/></a></td>
        <td width="432" background="/images/bjB1.gif"> </td>
        <td width="4"><img src="/images/tuB1.gif" width="4" height="28" /></td>
      </tr>
      <tr>
        <td height="59" colspan="7"><table width="100%" border="0" cellpadding="0" cellspacing="0" background="/images/bjB2.gif" class="toptable">
          <tr>
            <td width="17%" height="58" align="center"> </td>
            <td width="5%" align="center"><img src="/images/tuB4.gif" width="30" height="30" /></td>
            <td width="4%" align="center"><span class="STYLE1"></span></td>
            <td width="31%" align="center"><input name="searchkey" type="text" id="searchkey" size="40" /></td>
            <td width="8%" align="center"><select name="select">
              <option value="0">Please Select</option>
              <option value="1">News</option>
              <option value="2">Exhibit</option>
              <option value="3">Company</option>
            </select></td>
            <td width="9%" align="center"><a href="#"><img src="/images/tuB5.gif" width="74" height="24" border="0" /></a></td>
            <td width="10%" align="center" valign="middle"><img src="/images/tuB6.gif" width="3" height="5" />  <a href="Javascript:void(0)" class="kfs" onClick="foc()">站內(nèi)搜索</a></td>
            <td width="16%"> </td>
          </tr>

        </table></td>
      </tr>
    </table></td>
  </tr>
  <tr>
    <td width="6"><img src="/images/tuB2.gif" width="6" height="29" /></td>
    <td width="46" align="center" background="/images/bjB3.gif"><strong>公告</strong></td>
    <td width="904" background="/images/bjB3.gif"><a href="#" class="lan"> to trash cans, find the Public Utility Equipment </a><span class="STYLE2">new!</span><br /></td>
    <td width="6" ><img src="/images/tuB3.gif" width="6" height="29" /></td>
  </tr>
</table>
<script language="Javascript">
init();   //這里注意一定要寫在這里,要不然這個初始化函數(shù)就會報錯說找不到對像
</script>

 

這種的效果如下:

先看首頁:

再看按下訂單查看按鈕后的效果:我用的觸發(fā)腳本是在上面代碼中的onclick="menushow(2)"即傳遞一個2做為實參,從而設(shè)置history.dmenu=2這樣在頁面刷新加載時就會判斷出當(dāng)前狀態(tài)了.因為這個變量是相對于瀏覽器的.效果如下:

今天測試時發(fā)現(xiàn)了一個問題,得用上面寫的方法時對IE不支持,在火狐上沒有問題,所以對程序進行了下小修改.過程是這樣的.對于IE瀏覽器使用session來判斷,每按一個按鈕時就寫一個session("dmenu")為相應(yīng)的值,然后把這個值寫在頁面的一個隱藏域里,然后在頁面初始化時判斷是使用的什么類型瀏覽器,如果是IE的就執(zhí)行通過session來判斷的函數(shù),而這個session則是通過獲取那個隱藏域里的值,而如果是非IE瀏覽器就運用上面我昨天寫的也就是上面的init函數(shù)來進行.判斷代碼如下:

<script language="Javascript">
if(navigator.userAgent.indexOf("MSIE")>0){
    init2();//是IE瀏覽器就執(zhí)行這個
 }else{
  init();
  //否則執(zhí)行這個

 }
</script>

如此一來就完美的解決了這個問題.也許有朋友會說用session就可以了,但經(jīng)過我的實驗是用session火狐的根本不認,我也不知道什么原因,所以只好用我這個方法了.如果你有好方法請告訴我.

JavaScript技術(shù)利用js跨頁面保存變量做菜單的方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本女人下面毛茸茸 | 亚洲色大成网站WWW永久麻豆 | 亚洲综合色五月久久婷婷 | 亚洲一区精品在线 | 国产成人一区免费观看 | 黄梅戏mp3大全| 国产午夜高潮熟女精品AV | 国产伦精品一区二区免费 | 久久这里只有精品无码3D | 久久99精品国产免费观看 | 内射少妇36P亚洲区 内射少妇36P九色 | 久久亚洲人成国产精品 | 久久成人免费观看全部免费 | 97在线观看免费 | 嫩B人妻精品一区二区三区 内射一区二区精品视频在线观看 | 成人a视频片在线观看免费 成人a毛片久久免费播放 | 观看免费做视频 | 美女18毛片免费视频 | 国产一区二区在线观看免费 | 国产欧美一区二区精品性色tv | 久久免费看视频 | 国内精品久久久久影院男同志 | 男神插曲女生软件完整版 | 老湿机一区午夜精品免费福利 | 久久国产欧美 | 精品夜夜澡人妻无码AV蜜桃 | 欧美一夜爽爽爽爽爽爽 | 俄罗斯aaaaa一级毛片 | 国内免费视频成人精品 | 青草国产超碰人人添人人碱 | 嫩草影院久久国产精品 | 四虎影视库永久免费 | 熟女久久久久久久久久久 | 久久91精品久久久久久水蜜桃 | 亚洲国产货青视觉盛宴 | 国产高清视频在线观看97 | 国产精品人成在线播放新网站 | 99re在这里只有精品 | 麻豆国产MV视频 | 欧美黑白配性xxxxx | 99久久久免费精品国产 |