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

首頁 > 開發 > 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不支持。

相關:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久精品一区二区| 日本一本a高清免费不卡| 亚洲毛片在线看| 疯狂欧美牲乱大交777| 亚洲国产精品成人av| 欧美激情a∨在线视频播放| 日本午夜在线亚洲.国产| 亚洲free嫩bbb| 久久久之久亚州精品露出| 久久99热精品这里久久精品| 欧美日韩国产丝袜美女| 国产精品免费久久久久久| 蜜臀久久99精品久久久久久宅男| 8090理伦午夜在线电影| 国产伦精品免费视频| 粗暴蹂躏中文一区二区三区| 欧美最猛黑人xxxx黑人猛叫黄| 日韩欧美国产网站| 亚洲一区二区三区sesese| 福利一区福利二区微拍刺激| 欧美日韩一区免费| 中文字幕亚洲欧美日韩在线不卡| 91av免费观看91av精品在线| 精品成人国产在线观看男人呻吟| 亚洲图片制服诱惑| 国产精品99一区| 最近2019免费中文字幕视频三| 福利一区视频在线观看| 日韩精品视频在线| 国产精品丝袜久久久久久高清| 日本午夜在线亚洲.国产| 国模视频一区二区三区| 欧美在线免费观看| 亚洲一区二区三区视频播放| 亚洲男人7777| 色777狠狠综合秋免鲁丝| 日韩精品免费在线观看| 日韩黄色av网站| 欧美激情视频网站| 亚洲精品按摩视频| 日韩中文字幕在线视频播放| 国内自拍欧美激情| 亚洲91精品在线观看| 午夜精品一区二区三区在线视| 福利视频导航一区| 亚洲最大的成人网| 中文字幕一区电影| 亚洲已满18点击进入在线看片| 精品视频偷偷看在线观看| 欧美日韩国产中字| 精品久久久视频| 日韩在线观看免费av| 欧美激情欧美狂野欧美精品| 国产成人激情小视频| 国产v综合ⅴ日韩v欧美大片| 96国产粉嫩美女| 欧美成aaa人片在线观看蜜臀| 亚洲国产天堂久久国产91| 国产成人亚洲综合| 成人午夜激情网| 动漫精品一区二区| 九色精品美女在线| 亚洲自拍中文字幕| 国产精品日韩在线播放| 欧美精品一区二区三区国产精品| 91午夜理伦私人影院| 国产情人节一区| 亚洲精品福利资源站| 亚洲图片欧美日产| 国产日韩欧美在线视频观看| 欧美福利视频网站| 欧美乱大交xxxxx另类电影| 91亚洲一区精品| 欧美美最猛性xxxxxx| 亚洲欧美一区二区三区情侣bbw| 神马久久桃色视频| 日韩在线观看视频免费| 2025国产精品视频| 亚洲国产福利在线| 亚洲电影第1页| 亚洲午夜激情免费视频| 久久天天躁狠狠躁夜夜躁2014| 日韩久久午夜影院| 久久这里只有精品视频首页| 一区二区欧美亚洲| 8x海外华人永久免费日韩内陆视频| 国产精品女人久久久久久| 久久影视电视剧免费网站| 九九精品在线观看| 性色av香蕉一区二区| 亚洲欧美日韩久久久久久| 日本高清不卡的在线| 欧美限制级电影在线观看| 91大神福利视频在线| 伊人男人综合视频网| 国产日韩欧美中文在线播放| 911国产网站尤物在线观看| 日韩国产高清视频在线| 亚洲日本中文字幕| 久久综合伊人77777尤物| 久久久久久亚洲| 麻豆一区二区在线观看| 黄网动漫久久久| 国产免费一区二区三区在线观看| 久久精品男人天堂| 欧美高清videos高潮hd| 最近2019中文字幕第三页视频| 亚洲欧美另类国产| 欧美日韩激情视频8区| 久久影视三级福利片| 欧美超级乱淫片喷水| 国产综合在线观看视频| 欧美一级bbbbb性bbbb喷潮片| 少妇高潮久久77777| 亚洲欧美色婷婷| 国产精品视频中文字幕91| 色婷婷久久一区二区| 久久精品视频在线观看| 午夜精品久久久久久久白皮肤| 欧美激情亚洲综合一区| 国产欧美婷婷中文| 日韩有码在线播放| 成人看片人aa| 亚洲老板91色精品久久| 欧美性猛交xxxx| 欧美亚洲另类激情另类| 亚洲精品之草原avav久久| 亚洲在线第一页| 久热国产精品视频| 精品亚洲一区二区三区在线观看| 国产亚洲精品久久久| 欧美精品在线网站| 中文字幕日韩免费视频| 亚洲成人久久久| 亚洲91av视频| 在线观看视频亚洲| 日本精品视频在线观看| 国产一区二区三区视频在线观看| 亚洲xxxxx性| 亚洲精品国产精品自产a区红杏吧| 久久久久亚洲精品成人网小说| 97视频在线观看成人| 日本欧美中文字幕| 蜜臀久久99精品久久久无需会员| 欧美日韩一区二区精品| 久久久国产精品x99av| 亚洲аv电影天堂网| 欧美性色xo影院| 91沈先生在线观看| 91在线观看免费高清完整版在线观看| 日韩视频亚洲视频| 欧美老女人在线视频| 97精品一区二区视频在线观看| 久久久之久亚州精品露出| 日韩精品在线电影| 91九色在线视频| 国产亚洲精品久久久久久牛牛| 国产精品视频网站| 最近2019中文字幕一页二页| 秋霞成人午夜鲁丝一区二区三区| 久久久精品美女| 欧美另类69精品久久久久9999| 成人在线播放av| 97精品国产aⅴ7777|