中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ajax如何實現后退

發布時間:2021-10-12 18:39:30 來源:億速云 閱讀:154 作者:小新 欄目:web開發

這篇文章主要為大家展示了“ajax如何實現后退”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“ajax如何實現后退”這篇文章吧。

一、使用iframe,通過document.write產生歷史

代碼如下:


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


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

復制代碼 代碼如下:


<!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邏輯代碼,如下

復制代碼 代碼如下:


<!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頁面中

復制代碼 代碼如下:


<!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來產生歷史,也需要一個單獨的html頁面(iframe)。不同的是回調邏輯不是寫在iframe.onload中,而直接寫在html頁面中(上一篇則是空的html架子)。blank.html如下

復制代碼 代碼如下:


<!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事件處理后退

代碼如下:


<!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的值,每次修改后地址欄均會有所體現。在window.onhashchange中監聽該事件。通過hash的值取對應的歷史。
較iframe的好處是可以復制地址欄的url直接進入該歷史記錄,缺點是IE6/7不支持。 

以上是“ajax如何實現后退”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

青铜峡市| 南郑县| 玛纳斯县| 余姚市| 澄江县| 泾阳县| 哈巴河县| 双柏县| 留坝县| 班戈县| 陕西省| 益阳市| 黄浦区| 鄂托克前旗| 沙雅县| 长岛县| 嘉峪关市| 甘泉县| 克东县| 剑川县| 夏邑县| 呼图壁县| 民县| 湛江市| 南木林县| 邢台市| 肃宁县| 伊川县| 休宁县| 莒南县| 南宁市| 濮阳市| 云和县| 东丽区| 酒泉市| 汝城县| 灌南县| 甘泉县| 永新县| 泽普县| 光泽县|