ajax后退解決方案_AJAX教程
教程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類代碼分享,需要的朋友可以參考下。
相關(guān)AJAX教程:
- Ajax中瀏覽器的緩存問(wèn)題解決方法
- AJAX和WebService實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)具體代碼
- ajax 登錄功能簡(jiǎn)單實(shí)現(xiàn)(未連接數(shù)據(jù)庫(kù))
- AJAX和WebService實(shí)現(xiàn)郵箱驗(yàn)證(無(wú)刷新驗(yàn)證郵件地址是否合法)
- AJAX和三層架構(gòu)實(shí)現(xiàn)分頁(yè)功能具體思路及代碼
- 使用AJAX返回WebService里的集合具體實(shí)現(xiàn)
- AJAX獲取服務(wù)器當(dāng)前時(shí)間及時(shí)間格式輸出處理
- ajax傳遞多個(gè)參數(shù)具體實(shí)現(xiàn)
- ajax傳遞一個(gè)參數(shù)具體實(shí)現(xiàn)
- 滑輪滾動(dòng)到頁(yè)面底部ajax加載數(shù)據(jù)配合jsonp實(shí)現(xiàn)探討
- jQery ajax——load()方法示例介紹
- jQuery+Ajax實(shí)現(xiàn)表格數(shù)據(jù)不同列標(biāo)題排序(為表格注入活力)
AJAX教程Rss訂閱編程教程搜索
AJAX教程推薦
- Ajax與JSON的一些學(xué)習(xí)總結(jié)
- Ajax常見(jiàn)問(wèn)題有哪些?
- 掌握Ajax第2部分使用
- Json數(shù)據(jù)異步綁定到界面的Table并且自動(dòng)刷新原理及代碼
- Ajax中瀏覽器的緩存問(wèn)題解決方法
- 解讀AJAX是否能夠取代桌面應(yīng)用程序
- XMLHttpRequest和AJAX入主Web開(kāi)發(fā)
- 使用AJAX技術(shù)實(shí)現(xiàn)網(wǎng)頁(yè)無(wú)閃自動(dòng)局部刷新
- JQuery+ajax實(shí)現(xiàn)批量上傳圖片(自寫(xiě))
- 實(shí)現(xiàn)基于Ajax的無(wú)限級(jí)菜單
猜你也喜歡看這些
- 解析AJAX進(jìn)度條
- 掌握 Ajax,第 1 部分 Ajax 簡(jiǎn)介
- 揭秘Ajax 的安全-不容忽視的問(wèn)題
- 滑輪滾動(dòng)到頁(yè)面底部ajax加載數(shù)據(jù)配合jsonp實(shí)現(xiàn)探討
- 用AJAX編寫(xiě)用戶注冊(cè)實(shí)例及技術(shù)小結(jié)
- AJAX實(shí)例入門(mén)
- 巧用Ajax和RSS做個(gè)人門(mén)戶網(wǎng)站
- Ajax創(chuàng)建XMLHttp對(duì)象的完美兼容性代碼
- 解讀Ajax如何實(shí)現(xiàn)頁(yè)面loading效果!
- JavaScript如何控制Session實(shí)現(xiàn)原理及代碼
- 相關(guān)鏈接:
- 教程說(shuō)明:
AJAX教程-ajax后退解決方案。