国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > AJAX > 正文

ajax后退解決方案

2024-09-01 08:26:33
字體:
來源:轉載
供稿:網友
一、使用iframe,通過document.write產生歷史
復制代碼 代碼如下:VeVb.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>

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

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

<!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頁面中
復制代碼 代碼如下:VeVb.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來產生歷史,也需要一個單獨的html頁面(iframe)。不同的是回調邏輯不是寫在iframe.onload中,而直接寫在html頁面中(上一篇則是空的html架子)。blank.html如下
復制代碼 代碼如下:VeVb.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一樣所有瀏覽器均支持。
四、通過修改location.hash產生歷史,hashchange事件處理后退
復制代碼 代碼如下:VeVb.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的值,每次修改后地址欄均會有所體現。在window.onhashchange中監聽該事件。通過hash的值取對應的歷史。
較iframe的好處是可以復制地址欄的url直接進入該歷史記錄,缺點是IE6/7不支持。

相關:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 九龙坡区| 辉县市| 茶陵县| 吴川市| 青海省| 蓝田县| 都匀市| 西乌珠穆沁旗| 蒙自县| 靖宇县| 徐汇区| 荆门市| 博爱县| 津市市| 潮州市| 慈利县| 保定市| 宁河县| 贵州省| 分宜县| 江城| 四川省| 池州市| 无棣县| 永平县| 德兴市| 会东县| 宜川县| 阳信县| 泰宁县| 新野县| 邳州市| 上虞市| 澎湖县| 丹凤县| 砚山县| 牟定县| 美姑县| 丹凤县| 绵竹市| 壤塘县|