欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ajax后退解決方案

 更新時(shí)間:2011年09月20日 23:31:44   作者:  
ajax后退解決方案,需要的朋友可以參考下。
一、使用iframe,通過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)擊按鈕后更新頁面DOM(模擬ajax提交),會發(fā)現(xiàn)瀏覽器后退按鈕可用了。點(diǎn)擊后退,可返回到前一個(gè)狀態(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" 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架子,沒有JS邏輯代碼,如下
復(fù)制代碼 代碼如下:

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

每次ajax操作會往iframe.src的問號后附加一個(gè)數(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" 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來產(chǎn)生歷史,也需要一個(gè)單獨(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事件處理后退
復(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的值,每次修改后地址欄均會有所體現(xiàn)。在window.onhashchange中監(jiān)聽該事件。通過hash的值取對應(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

相關(guān)文章

  • ajax實(shí)現(xiàn)加載數(shù)據(jù)功能

    ajax實(shí)現(xiàn)加載數(shù)據(jù)功能

    這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)加載數(shù)據(jù)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • webform使用ajax訪問后端接口的兩種方法小結(jié)

    webform使用ajax訪問后端接口的兩種方法小結(jié)

    這篇文章主要介紹了webform使用ajax訪問后端接口的兩種方法小結(jié),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-11-11
  • 建一個(gè)XMLHttpRequest對象池

    建一個(gè)XMLHttpRequest對象池

    建一個(gè)XMLHttpRequest對象池...
    2007-04-04
  • Ajax實(shí)現(xiàn)城市二級聯(lián)動(一)

    Ajax實(shí)現(xiàn)城市二級聯(lián)動(一)

    這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)城市二級聯(lián)動的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • 詳解Ajax跨域(jsonp) 調(diào)用JAVA后臺

    詳解Ajax跨域(jsonp) 調(diào)用JAVA后臺

    本篇文章主要介紹了詳解Ajax跨域(jsonp) 調(diào)用JAVA后臺 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • ajax 實(shí)現(xiàn)微信網(wǎng)頁授權(quán)登錄的方法

    ajax 實(shí)現(xiàn)微信網(wǎng)頁授權(quán)登錄的方法

    這篇文章主要介紹了ajax 實(shí)現(xiàn)微信網(wǎng)頁授權(quán)登錄的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-03-03
  • ajax中的async屬性值之同步和異步及同步和異步區(qū)別

    ajax中的async屬性值之同步和異步及同步和異步區(qū)別

    在Jquery中ajax方法中async用于控制同步和異步,當(dāng)async值為true時(shí)是異步請求,當(dāng)async值為fase時(shí)是同步請求。ajax中async這個(gè)屬性,用于控制請求數(shù)據(jù)的方式,默認(rèn)是true,即默認(rèn)以異步的方式請求數(shù)據(jù)。
    2015-10-10
  • Ajax的小貼士使用小結(jié)

    Ajax的小貼士使用小結(jié)

    Ajax的小貼士使用小結(jié)...
    2007-10-10
  • Ajax的特性及亂碼問題

    Ajax的特性及亂碼問題

    ajax的全稱是asynchronous javascript and XML ,它是異步的js和XML。它是局部刷新,異步操作。這篇文章給大家介紹了ajax的特性及亂碼問題,感興趣的朋友一起看看吧
    2017-07-07
  • AJAX用于判定用戶是否注冊

    AJAX用于判定用戶是否注冊

    這篇文章主要為大家詳細(xì)介紹了AJAX用于判定用戶是否注冊,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評論