色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

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

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

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

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

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

 

<script type="text/JavaScript">
<!--
 function foc(){
 document.getElementById("searchkey").focus();
 }   //這是做搜索時(shí)一個(gè)函數(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;
    }
  }
 }
 //上面是具體的判斷那個(gè)變量然后據(jù)變量的值來進(jìn)行圖片的變換從而達(dá)到我們要的效果.


 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)的值從而在頁面加載時(shí)能根據(jù)這個(gè)值來進(jìn)行圖片的變換

//-->
</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();   //這里注意一定要寫在這里,要不然這個(gè)初始化函數(shù)就會(huì)報(bào)錯(cuò)說找不到對(duì)像
</script>

 

這種的效果如下:

先看首頁:

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

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

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

 }
</script>

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

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

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

主站蜘蛛池模板: 澳门| 大洼县| 平远县| 海丰县| 沐川县| 黎川县| 江陵县| 铁力市| 安仁县| 涡阳县| 南木林县| 正阳县| 舒兰市| 通城县| 家居| 新民市| 唐河县| 荔波县| 贡觉县| 卢龙县| 德兴市| 龙口市| 眉山市| 揭阳市| 三亚市| 柘荣县| 乐亭县| 三江| 达孜县| 盈江县| 兴安县| 农安县| 大同县| 周口市| 沧源| 图们市| 榕江县| 五家渠市| 阳东县| 大埔县| 吴忠市|