时候,我们会希望网页自动跳转,应用场景包括:
下面总结下如何在前端页面中控制跳转的方法:
利用html的refresh
<meta http-equiv="refresh" content="0;url=index.html">
其中0表示0秒以后跳转,可以自行设定时间。
利用js的href属性
window.location.href='index.html';
如果要设定延迟时间,则加上setTimeout
setTimeout("javascript:location.href='index.html'", 5000);
利用js的navigate方式
window.navigate("index.html");
自动刷新页面
在上述方式中,如果跳转的页面就是本页面,那么就是自动刷新页面的功能。
或者使用reload
location.reload()
跳转到上一页,下一页的方式
window.history.go(-1);
其中 -1 表示上一页,如果没有负号的就是表示下一页
如果不是1而是 2,3,4......n 则表示前进或者后退 n 页
后退还可以用
window.history.back();
两者的区别是:
go(-1):返回上一页,原页面表单中的内容会丢失;
back():返回上一页,原页表表单中的内容会保留。
前进则对应的是:
history.forward():
此外,还有一个参数 history.length 记录了页面前进的序号,如果等于0表示第一页
怎么选择
至此,自动跳转页面、刷新页面、前后切换的方法都齐了!方法多了就有了选择恐惧症?
基本原则:
单纯的页面跳转建议就用html的refresh方法,无需js代码,很简洁。
如果比较复杂,涉及js代码的业务功能,再加上跳转功能的,就用js的各种方法。
此外还要考虑页面是否刷新的问题,希望刷新就用go,否则用back/forward
久都没有去慕课网学习学习了,刚恰好就看见了一个用的比较多的小例子——页面回到顶部,记得之前自己也是在初学web时,被这个坑了一回,因此今天特地拿来分享分享……
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>页面回到顶部</title>
<link rel="stylesheet" type="text/css" href="mycss.css">
<script type="text/javascript" src="myjs.js"></script>
</head>
<body>
<a href="javascript:;" id="btn" title="回到顶部"></a>
<div class="bg">
<img src="images/tb_bg.jpg" alt="" />
</div>
</body>
</html>其中需要引入自己写的一个样式文件和一个js文件:
#btn {
width: 40px;
height: 40px;
position: fixed;
display: none;
right: 65px;
bottom: 10px;
background: url(images/top_bg.png) no-repeat left top;
}
#btn:hover {
background: url(images/top_bg.png) no-repeat 0 -39px;
}
.bg {
width: 1190px;
margin: 0 auto;
}js文件:
//页面加载完毕后触发
window.onload = function {
var obtn = document.getElementById('btn');
var clientHeight=document.documentElement.clientHeight;//获取页面可视区域的高度
var timer = null; //存放定时器
var isTop=true;
//滚动条滚动时触发
window.onscroll=function{
var osTop = document.documentElement.scrollTop || document.body.scrollTop;
if(osTop>=clientHeight){
obtn.style.display="block";
}else{
obtn.style.display="none";
}
if(!isTop){
clearInterval(timer);
}
isTop=false;
}
obtn.onclick = function {
timer = setInterval(function { //设置定时器
//获取滚动条距离顶部的高度
var osTop = document.documentElement.scrollTop || document.body.scrollTop;
var ispeed=osTop/5;
document.documentElement.scrollTop = document.body.scrollTop =osTop-ispeed;
isTop=true;
if(osTop==0){
clearInterval(timer);
}
}, 30);
}
}文件存放路径:
基本“回到顶部”效果就这样子实现,只是我不会在文章中添加动态效果(就是实时的添加这个动态效果图),求大神赐教!
window.history.pushState(null, null, window.location.href);
window.addEventListener("popstate", function () {
window.history.pushState(null, null, window.location.href);
});品同学总是会提出各种稀奇古怪的需求,比如qj用户的返回操作。。。
上面的代码经常被用来禁止网页页面的返回,经过个人的测试(Chrome/92.0.4497.0),必须在用户有了交互之后才能生效,否则不生效;
*请认真填写需求信息,我们会在24小时内与您取得联系。