一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

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

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

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

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

 

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

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

//如果history.dmenu沒有定義則設置為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;
    }
  }
 }
 //上面是具體的判斷那個變量然后據變量的值來進行圖片的變換從而達到我們要的效果.


 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;
  }
 }
 //按下相關圖片按鈕后設置history.dmenu為相應的值從而在頁面加載時能根據這個值來進行圖片的變換

//-->
</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()">站內搜索</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();   //這里注意一定要寫在這里,要不然這個初始化函數就會報錯說找不到對像
</script>

 

這種的效果如下:

先看首頁:

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

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

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

 }
</script>

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

JavaScript技術利用js跨頁面保存變量做菜單的方法,轉載需保留來源!

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

主站蜘蛛池模板: 我被黑人巨大开嫩苞在线观看 | 国产精品视频h | 7799国产精品久久久久99 | 欧美成人网7777视频 | 久久成人影视 | 小黄网站有哪些在线观看 | 免费国产成人综合 | 91视频播放| 亚洲美女aⅴ久久久91 | 亚洲第一页在线观看 | 91精品网站 | 在线高清免费爱做网 | 99精品视频在线播放2 | 最新国产在线观看福利91 | 天天色影院 | 怡红院亚洲红怡院天堂麻豆 | 午夜日本一区二区三区 | 亚洲成人手机在线观看 | 色老板视频 | 国产91久久久久久久免费 | 美女胸又www又黄的网站视频 | 午夜毛片网站 | 成年网站视频在线观看 | 中文字幕不卡一区 二区三区 | 在线精品视频免费观看 | 岛国美女全棵写真视频在线观看 | 一级做a爰片性色毛片中国 一级做a爰性色毛片 | 激情文学888 | 综合 欧美 国产 视频二区 | 国产成人综合在线 | 国产精品亚洲视频 | 极品吹潮视频大喷潮tv | 男人插女人视频网站 | 四虎在线精品免费高清在线 | 怡红院免费全部视频在线视频 | 亚洲欧洲日韩国产一区二区三区 | 99视频精品全部国产盗摄视频 | 欧美日韩国产精品 | 92看片淫黄大片欧美看国产片 | 激情91| 88av视频|