<script language="javascript">
var refer=document.referrer
document.getElementById('backurl').value=refer
</script>
“HTTP_REFERER”
链接到当前页面的前一页面的 URL 地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改 HTTP_REFERER。因此,这个变量不总是真实正确的。
注意 document.referrer和“HTTP_REFERER” 中间差一个字母,却是不同的概念的东东,请注意使用
js中的referrer使用,返回上一页
在js中写上location.href = document.referrer就可以实现跳转到上一个页面了,让用户觉得体验很好
但是在IE中referrer就没那么尽人意了啊,IE会清空referrer
众所周知,我们web开发人员痛恨IE浏览器,因为IE不支持标准,标准外的默认行为又和其他浏览器经常不一致:
在IE中用javascript做跳转,比如用window.location.href = “http://www.google.com”google无法取到浏览器请求的HTTP referrer,因为IE清空了document.referrer
而其他主流浏览器Firefox和Chrome都会保留referrer,这意味着IE又要享受“部长级”特殊待遇了:
view source
if (/MSIE (\d+\.\d+)/.test(navigator.userAgent)){
var referLink = document.createElement('a')
referLink.href = url
document.body.appendChild(referLink)
referLink.click()
}else {
location.href = url
}
这样的原理就是给IE浏览器的页面偷偷加了个链接,然后自动点这个链接,于是referrer就能保留了。
页面本身是不具备保存历史数据的功能的,需要借助其它手段来实现,常用方法如下:异步更新页面。这种方法实际上页面是没有刷新的,通过AJAX导步获取信息来更新页面,这样可以保留原页面需要保留的数据。一些网站的发表评论后,评论内容更新,用的就是这个方法。
使用COOKIE保存。把需要保存的数据存储到COOKIE中,页面更新时,读取COOKIE渲染到页面上。比较常见的如:登录框记录用户名,下次登录无须重新输入。但COOKIE存储的数据量有限,不适合大的数据存储。
服务器端保存数据。与COOKIE保存类似,只不过内容是保存在服务器端,利用会话机制在页面更新时从服务器读取内容重新渲染。这是一种常见的而保险的方法。像一些文本编辑器,保存草稿等,就是通过这样的方式实现的
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)