ajax浏览器后退 iframe,ajax后退解决方案

本文介绍了四种利用iframe和location.hash来管理浏览器历史状态的方法,包括通过document.write、修改iframe.src以及监听hashchange事件等技术,以实现ajax提交后退功能。这些方法在不同浏览器中的兼容性和优缺点也进行了探讨。
摘要由CSDN通过智能技术生成

一、使用iframe,通过document.write产生历史

0
0

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;

}

点击按钮后更新页面DOM(模拟ajax提交),会发现浏览器后退按钮可用了。点击后退,可返回到前一个状态。

这种方式缺点是只支持IE和Firefox。

ajax后退解决方案(二)

二、使用iframe,通过修改iframe.src产生历史

0
0

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;

}

较上一篇多了个blank.html,是一个空html架子,没有JS逻辑代码,如下

blank.html

每次ajax操作会往iframe.src的问号后附加一个数字以记录历史。点击后退按钮,iframe的onload事件中获取iframe的url,根据问号后的数字去取记录。

所有浏览器均支持该方式。缺点是如果主页面中存在其它iframe,且修改了其src。历史管理会混乱。

三、使用iframe,通过修改iframe.src产生历史,回调写在iframe对应的html页面中

0
0

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;

}

与方案2相同也是使用iframe.src来产生历史,也需要一个单独的html页面(iframe)。不同的是回调逻辑不是写在iframe.onload中,而直接写在html页面中(上一篇则是空的html架子)。blank.html如下

blank.html

var url= location.href;

if(url.indexOf('?')>-1) {

var idx = url.substr(url.indexOf('?')+1);

parent.History.get(idx);

}

和方案2一样所有浏览器均支持。

四、通过修改location.hash产生历史,hashchange事件处理后退

0
0

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;

}

每次ajax操作去改变location.hash的值,每次修改后地址栏均会有所体现。在window.onhashchange中监听该事件。通过hash的值取对应的历史。

较iframe的好处是可以复制地址栏的url直接进入该历史记录,缺点是IE6/7不支持。

文中代码打包下载

相关:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值