ajax如何實(shí)現(xiàn)后退-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“ajax如何實(shí)現(xiàn)后退”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“ajax如何實(shí)現(xiàn)后退”這篇文章吧。

在平羅等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站建設(shè)、成都做網(wǎng)站 網(wǎng)站設(shè)計(jì)制作按需定制,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),營銷型網(wǎng)站建設(shè),外貿(mào)網(wǎng)站建設(shè),平羅網(wǎng)站建設(shè)費(fèi)用合理。

一、使用iframe,通過document.write產(chǎn)生歷史


代碼如下:


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>0</title>
</head>
<body>
<input type="button" value="加1" onclick="add()" />
<div id="info" >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)擊按鈕后更新頁面DOM(模擬ajax提交),會發(fā)現(xiàn)瀏覽器后退按鈕可用了。點(diǎn)擊后退,可返回到前一個狀態(tài)。
這種方式缺點(diǎn)是只支持IE和Firefox。
ajax后退解決方案(二)
二、使用iframe,通過修改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" >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邏輯代碼,如下


復(fù)制代碼 代碼如下:


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



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


復(fù)制代碼 代碼如下:


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>0</title>
</head>
<body>
<input type="button" value="加1" onclick="add()" />
<div id="info" >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來產(chǎn)生歷史,也需要一個單獨(dú)的html頁面(iframe)。不同的是回調(diào)邏輯不是寫在iframe.onload中,而直接寫在html頁面中(上一篇則是空的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一樣所有瀏覽器均支持。
四、通過修改location.hash產(chǎn)生歷史,hashchange事件處理后退


代碼如下:


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>0</title>
</head>
<body>
<input type="button" value="加1" onclick="add()" />
<div id="info" >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的值,每次修改后地址欄均會有所體現(xiàn)。在window.onhashchange中監(jiān)聽該事件。通過hash的值取對應(yīng)的歷史。
較iframe的好處是可以復(fù)制地址欄的url直接進(jìn)入該歷史記錄,缺點(diǎn)是IE6/7不支持。


以上是“ajax如何實(shí)現(xiàn)后退”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

網(wǎng)站名稱:ajax如何實(shí)現(xiàn)后退-創(chuàng)新互聯(lián)
文章出自:http://muchs.cn/article30/dphhso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、微信公眾號小程序開發(fā)、營銷型網(wǎng)站建設(shè)、搜索引擎優(yōu)化、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化