ajax后退解決方案_AJAX教程

      編輯Tag賺U幣
      教程Tag:暫無(wú)Tag,歡迎添加,賺取U幣!

      推薦:防止ajax重復(fù)請(qǐng)求的方法(GET和POST)
      防止ajax重復(fù)請(qǐng)求的方法(GET和POST) ,需要的朋友可以參考下。

      一、使用iframe,通過(guò)document.write產(chǎn)生歷史
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8"/>
      <title>0</title>
      </head>
      <body>
      <input type="button" value="加1" onclick="add()" />
      <div id="info" style="border:red 1px solid;width:200px;padding:10px;margin:5px;">0</div>
      </body>
      </html>
      <script src="history-0.1.js"></script>
      <script>
      var info = document.getElementById('info');
      var i = 1;
      function add() {
      info.innerHTML = i;
      document.title = i;
      var data = {
      param : i,
      func : func
      };
      History.push(data);
      i++;
      }
      History.push({param:0, func: func});
      function func(i) {
      info.innerHTML = i;
      document.title = i;
      }
      </script>

      點(diǎn)擊按鈕后更新頁(yè)面DOM(模擬ajax提交),會(huì)發(fā)現(xiàn)瀏覽器后退按鈕可用了。點(diǎn)擊后退,可返回到前一個(gè)狀態(tài)。
      這種方式缺點(diǎn)是只支持IE和Firefox。
      ajax后退解決方案(二)
      二、使用iframe,通過(guò)修改iframe.src產(chǎn)生歷史
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8" />
      <title>0</title>
      </head>
      <body>
      <input type="button" value="加1" onclick="add()" />
      <div id="info" style="border:red 1px solid;width:200px;padding:10px;margin:5px;">0</div>
      </body>
      </html>
      <script src="history-0.2.js"></script>
      <script>
      var info = document.getElementById('info');
      var i = 1;
      function add() {
      info.innerHTML = i;
      document.title = i;
      var data = {
      param : i,
      func : func
      };
      History.push(data);
      i++;
      }
      History.push({param:0, func: func});
      function func(i) {
      info.innerHTML = i;
      document.title = i;
      }
      </script>

      較上一篇多了個(gè)blank.html,是一個(gè)空html架子,沒(méi)有JS邏輯代碼,如下
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE HTML>
      <html>
      <head>
      <title>blank.html</title>
      </head>
      <body>
      </body>
      </html>

      每次ajax操作會(huì)往iframe.src的問(wèn)號(hào)后附加一個(gè)數(shù)字以記錄歷史。點(diǎn)擊后退按鈕,iframe的onload事件中獲取iframe的url,根據(jù)問(wèn)號(hào)后的數(shù)字去取記錄。
      所有瀏覽器均支持該方式。缺點(diǎn)是如果主頁(yè)面中存在其它iframe,且修改了其src。歷史管理會(huì)混亂。
      三、使用iframe,通過(guò)修改iframe.src產(chǎn)生歷史,回調(diào)寫(xiě)在iframe對(duì)應(yīng)的html頁(yè)面中
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8" />
      <title>0</title>
      </head>
      <body>
      <input type="button" value="加1" onclick="add()" />
      <div id="info" style="border:red 1px solid;width:200px;padding:10px;">0</div>
      </body>
      </html>
      <script src="history-0.3.js"></script>
      <script>
      var info = document.getElementById('info');
      var i = 1;
      function add() {
      var data = {
      param : i,
      func : func
      };
      History.push(data);
      i++;
      }
      History.push({param:0, func: func});
      function func(i) {
      info.innerHTML = i;
      document.title = i;
      }
      </script>

      與方案2相同也是使用iframe.src來(lái)產(chǎn)生歷史,也需要一個(gè)單獨(dú)的html頁(yè)面(iframe)。不同的是回調(diào)邏輯不是寫(xiě)在iframe.onload中,而直接寫(xiě)在html頁(yè)面中(上一篇?jiǎng)t是空的html架子)。blank.html如下
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE HTML>
      <html>
      <head>
      <title>blank.html</title>
      </head>
      <body>
      <script>
      var url= location.href;
      if(url.indexOf('?')>-1) {
      var idx = url.substr(url.indexOf('?')+1);
      parent.History.get(idx);
      }
      </script>
      </body>
      </html>

      和方案2一樣所有瀏覽器均支持。
      四、通過(guò)修改location.hash產(chǎn)生歷史,hashchange事件處理后退
      復(fù)制代碼 代碼如下:www.wf0088.com

      <!DOCTYPE html>
      <html>
      <head>
      <meta charset="utf-8" />
      <title>0</title>
      </head>
      <body>
      <input type="button" value="加1" onclick="add()" />
      <div id="info" style="border:red 1px solid;width:200px;padding:10px;">0</div>
      </body>
      </html>
      <script src="history-0.4.js"></script>
      <script>
      var info = document.getElementById('info');
      var i = 1;
      function add() {
      var data = {
      param : i,
      func : func
      };
      History.push(data);
      i++;
      }
      History.push({param:0, func: func});
      function func(i) {
      info.innerHTML = i;
      document.title = i;
      }
      </script>

      每次ajax操作去改變location.hash的值,每次修改后地址欄均會(huì)有所體現(xiàn)。在window.onhashchange中監(jiān)聽(tīng)該事件。通過(guò)hash的值取對(duì)應(yīng)的歷史。
      較iframe的好處是可以復(fù)制地址欄的url直接進(jìn)入該歷史記錄,缺點(diǎn)是IE6/7不支持。

      相關(guān):

      分享:好用的AJAX類代碼分享
      好用的AJAX類代碼分享,需要的朋友可以參考下。

      來(lái)源:模板無(wú)憂//所屬分類:AJAX教程/更新時(shí)間:2013-04-22
      相關(guān)AJAX教程