濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > ajax后退解決方案

ajax后退解決方案

熱門(mén)標(biāo)簽:辦理一個(gè)400電話(huà)多少錢(qián) 電銷(xiāo)機(jī)器人適用范圍 察縣地圖標(biāo)注 如何用地圖標(biāo)注各分公司 信貸電銷(xiāo)機(jī)器人有用嗎 蓄意標(biāo)記地圖標(biāo)注 廣西ai語(yǔ)音電銷(xiāo)機(jī)器人哪家好 莆田防封電銷(xiāo)卡價(jià)格 接聽(tīng)電話(huà)機(jī)器人哪有
一、使用iframe,通過(guò)document.write產(chǎn)生歷史
復(fù)制代碼 代碼如下:

!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ù)制代碼 代碼如下:

!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ù)制代碼 代碼如下:

!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ù)制代碼 代碼如下:

!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ù)制代碼 代碼如下:

!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ù)制代碼 代碼如下:

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

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回退刷新頁(yè)面問(wèn)題的解決辦法
  • 通過(guò)history解決ajax不支持前進(jìn)/后退/刷新的問(wèn)題

標(biāo)簽:銅陵 張掖 阿拉善盟 益陽(yáng) 儋州 延邊 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ajax后退解決方案》,本文關(guān)鍵詞  ajax,后退,解決方案,ajax,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ajax后退解決方案》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于ajax后退解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    兖州市| 扶绥县| 分宜县| 隆回县| 连云港市| 望城县| 娄烦县| 阳曲县| 晴隆县| 利辛县| 楚雄市| 深圳市| 庆安县| 海原县| 象山县| 城固县| 余姚市| 垦利县| 郧西县| 阜城县| 衡山县| 洛浦县| 明星| 岚皋县| 平塘县| 广南县| 长宁县| 华阴市| 吉水县| 磐石市| 探索| 淮滨县| 望都县| 道孚县| 武义县| 遵化市| 米林县| 昭苏县| 秦安县| 嘉义县| 共和县|