亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

ajax后退解決方案

2024-09-01 08:31:30
字體:
來源:轉載
供稿:網友
ajax后退解決方案,需要的朋友可以參考下。

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

復制代碼 代碼如下:


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title>0</title>
</head>
<body>
<input type="button" value="加1" />
<div>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" />
<div>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" />
<div>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" />
<div>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不支持。
文中代碼打包下載

相關:

(v=vs.85).aspx

https://developer.mozilla.org/en/DOM/window.onhashchange

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美有码在线视频| 亚洲精品aⅴ中文字幕乱码| 亚洲精品日韩欧美| 亚洲天堂日韩电影| 亚洲欧美国产日韩天堂区| 亚洲欧美日韩视频一区| 久久成人在线视频| 中文字幕精品网| 亚洲美女在线视频| 久久综合色88| 精品国产一区二区三区久久狼黑人| 亚洲精品理论电影| 亚洲色图欧美制服丝袜另类第一页| 欧美激情一区二区三区在线视频观看| 久久精品91久久久久久再现| 亚洲欧美国产一本综合首页| 国产99久久精品一区二区永久免费| 伊人伊人伊人久久| 日韩中文字幕欧美| 中文字幕综合一区| 国产精品自产拍在线观| 最近2019年好看中文字幕视频| 色樱桃影院亚洲精品影院| 精品亚洲夜色av98在线观看| 精品亚洲夜色av98在线观看| 91免费观看网站| 国产精品久久久av| 国内精品400部情侣激情| 亚洲欧洲偷拍精品| 日韩国产高清污视频在线观看| 综合久久五月天| 国产精品久久二区| 欧美日韩中文在线观看| 欧美极品少妇与黑人| 国产主播喷水一区二区| 精品视频在线播放| 久久精品夜夜夜夜夜久久| 免费av一区二区| 欧美精品日韩www.p站| 色综合久久精品亚洲国产| 欧美精品videossex88| 午夜精品国产精品大乳美女| 亚洲精品白浆高清久久久久久| 国产精品黄色av| 成人国产在线视频| 国产欧美精品一区二区三区介绍| 91国产美女视频| 亚洲第一精品电影| 久久国产精彩视频| 91成人天堂久久成人| 亚洲欧美中文在线视频| 不卡av在线网站| 国产精品欧美一区二区三区奶水| 成人精品aaaa网站| 日本亚洲欧美三级| 国产精品草莓在线免费观看| 欧美激情啊啊啊| 国产精品女人久久久久久| 亚洲人成网站999久久久综合| 亚洲国产高清福利视频| 精品国偷自产在线| 国产极品jizzhd欧美| 狠狠综合久久av一区二区小说| 日韩精品中文字幕视频在线| 亚洲自拍欧美另类| 91嫩草在线视频| 精品亚洲aⅴ在线观看| 亚洲香蕉成视频在线观看| 大荫蒂欧美视频另类xxxx| 久久视频免费在线播放| 91美女片黄在线观看游戏| 一区二区三区无码高清视频| 日韩精品中文字幕有码专区| 九九热精品视频| 欧美成人精品不卡视频在线观看| 久久伊人免费视频| 欧美日韩中文字幕在线视频| 欧美午夜精品在线| 国产日韩在线观看av| 91精品国产91久久久久福利| 国产精品露脸自拍| 丝袜亚洲欧美日韩综合| 日韩激情视频在线| 精品久久久久国产| 欧美亚洲一级片| 国产又爽又黄的激情精品视频| 欧美日韩国产成人高清视频| 亚洲色图综合久久| 国产精品av电影| 国产精品成人一区二区| 色噜噜亚洲精品中文字幕| 国产精品成人久久久久| 色多多国产成人永久免费网站| 亚洲天堂网站在线观看视频| 国产精品吹潮在线观看| 亚洲人成电影网| 国产欧美精品在线| 色综合久久天天综线观看| 成人中心免费视频| 91亚洲精品一区二区| 日韩久久精品成人| 97热精品视频官网| 日韩一区二区欧美| 欧美性猛交xxxx免费看| 亚洲一级片在线看| 久久手机免费视频| 欧美小视频在线观看| 国产精品video| 亚洲香蕉av在线一区二区三区| 亚洲欧美日本伦理| 亚洲国产精品人人爽夜夜爽| 中文字幕成人精品久久不卡| 欧美日韩国产123| 亚洲欧美国产精品专区久久| 97人洗澡人人免费公开视频碰碰碰| 国产亚洲精品成人av久久ww| 亚洲男人天天操| 亚洲乱码一区av黑人高潮| 国产精品视频999| 日韩激情av在线播放| 色中色综合影院手机版在线观看| 亚洲人成网站色ww在线| 国产精品视频白浆免费视频| 欧美大肥婆大肥bbbbb| 久久亚洲精品国产亚洲老地址| 日韩精品亚洲精品| 激情懂色av一区av二区av| 亚洲黄页网在线观看| 狠狠干狠狠久久| 亚洲欧美综合v| 国产精品欧美一区二区三区奶水| 欧美资源在线观看| 成人免费自拍视频| 最近2019年日本中文免费字幕| 国产亚洲福利一区| 蜜臀久久99精品久久久久久宅男| 91最新国产视频| www高清在线视频日韩欧美| 91色在线观看| 欧美精品在线观看91| 91影视免费在线观看| 国产精品久久久久久亚洲调教| 国产精品永久免费观看| 精品久久香蕉国产线看观看亚洲| 亚洲精品福利免费在线观看| 欧美在线观看网址综合| 色诱女教师一区二区三区| 久操成人在线视频| 国产丝袜视频一区| 久久综合国产精品台湾中文娱乐网| 日韩在线免费视频观看| 中文字幕一区二区精品| 日韩国产欧美精品一区二区三区| 高清欧美电影在线| 狠狠躁夜夜躁人人爽超碰91| 日韩在线观看你懂的| 亚洲人成电影网站色| 久久精品视频网站| 欧美激情视频在线免费观看 欧美视频免费一| 国内精品国产三级国产在线专| 亚洲free性xxxx护士白浆| 久久久久亚洲精品成人网小说| 国产精品久久久久久av下载红粉| 欧美日韩一区二区精品|