婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ajax后退解決方案

ajax后退解決方案

熱門標簽:辦理一個400電話多少錢 電銷機器人適用范圍 察縣地圖標注 如何用地圖標注各分公司 信貸電銷機器人有用嗎 蓄意標記地圖標注 廣西ai語音電銷機器人哪家好 莆田防封電銷卡價格 接聽電話機器人哪有
一、使用iframe,通過document.write產生歷史
復制代碼 代碼如下:

!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>

點擊按鈕后更新頁面DOM(模擬ajax提交),會發現瀏覽器后退按鈕可用了。點擊后退,可返回到前一個狀態。
這種方式缺點是只支持IE和Firefox。
ajax后退解決方案(二)
二、使用iframe,通過修改iframe.src產生歷史
復制代碼 代碼如下:

!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>

較上一篇多了個blank.html,是一個空html架子,沒有JS邏輯代碼,如下
復制代碼 代碼如下:

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

每次ajax操作會往iframe.src的問號后附加一個數字以記錄歷史。點擊后退按鈕,iframe的onload事件中獲取iframe的url,根據問號后的數字去取記錄。
所有瀏覽器均支持該方式。缺點是如果主頁面中存在其它iframe,且修改了其src。歷史管理會混亂。
三、使用iframe,通過修改iframe.src產生歷史,回調寫在iframe對應的html頁面中
復制代碼 代碼如下:

!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來產生歷史,也需要一個單獨的html頁面(iframe)。不同的是回調邏輯不是寫在iframe.onload中,而直接寫在html頁面中(上一篇則是空的html架子)。blank.html如下
復制代碼 代碼如下:

!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一樣所有瀏覽器均支持。
四、通過修改location.hash產生歷史,hashchange事件處理后退
復制代碼 代碼如下:

!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的值,每次修改后地址欄均會有所體現。在window.onhashchange中監聽該事件。通過hash的值取對應的歷史。
較iframe的好處是可以復制地址欄的url直接進入該歷史記錄,缺點是IE6/7不支持。
文中代碼打包下載

相關:

http://msdn.microsoft.com/en-us/library/cc288209(v=vs.85).aspx

https://developer.mozilla.org/en/DOM/window.onhashchange

http://www.whatwg.org/specs/web-apps/current-work/multipage/history.html#event-hashchange

您可能感興趣的文章:
  • Ajax回退刷新頁面問題的解決辦法
  • 通過history解決ajax不支持前進/后退/刷新的問題

標簽:銅陵 張掖 平涼 阿拉善盟 益陽 儋州 延邊 鷹潭

巨人網絡通訊聲明:本文標題《ajax后退解決方案》,本文關鍵詞  ajax,后退,解決方案,ajax,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ajax后退解決方案》相關的同類信息!
  • 本頁收集關于ajax后退解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 句容市| 东丽区| 治多县| 阿克陶县| 洪江市| 新建县| 武山县| 饶平县| 抚宁县| 昌都县| 襄垣县| 时尚| 绥阳县| 太白县| 泰来县| 年辖:市辖区| 湖口县| 布尔津县| 罗江县| 伊春市| 六枝特区| 新安县| 鹰潭市| 南部县| 福州市| 金坛市| 正安县| 铜梁县| 织金县| 纳雍县| 永新县| 崇义县| 绥滨县| 察隅县| 乐业县| 江西省| 满城县| 巨野县| 仲巴县| 原阳县| 新宁县|