现在为了提高网站的用户体验,如添加页面切换动画,减少页面加载,很多网站为此都采用了无刷新技术来加载页面内容。目前很多框架都是实现了这一点来开发单页应用,比如angular,vue,react等,这篇文章将简单的介绍无刷新技术的一些实现方式。
hash路由的实现
hash是指url带 # 号的形式,采用这种方式方式兼容性比较好。我们只需要改变‘#’后面的内容,更新URL是不会引起页面跳转的。例如:
<a href="#/index">index</a>
<a href="#/about">about</a>
当点击了a标签后,url将会改为:域名/#index的样子,这里我们只需要通过js来监听URL的改变,如下:
window.addEventListener('hashchange',callback);
当监听到路由变化后,我们需要根据路由的变化通过callback回调函数来映射不同的页面,这里需要注意的在callback中不要去操作url,否则会出现死循环。下一步我们对路由进行注册,不同的路由执行不同的事情:
var routers=[
{path:'#index',component:function(){
console.log('index')
}},
{path:'#about',component:function(){
console.log('about')
}},
];
最后把routers和callback关联起来
function callback(){
for(r in routers){
if(routers[r].path==location.hash){
routers[r].component();
}
}
}
到这里点击不同的链接,我们在控制台可以看到对应的输出。然后里面的内容就需要我们异步去加载数据,然后渲染成dom,追加到页面即可。类似于
<!--html结构--->
<div id="main"></div>
<script>
var template='<div>渲染后的模板</div>';
document.getElementById('main').innerHTML=template;
</script>
这就是一个最简单的通过hash路由来实现页面的无刷新更新页面的。写的很简单,也很丑陋,但是思路就是这样。
Javascript刷新当前页面:history.go(0)、location.reload()、location=location、location.assign(location)、document.execCommand(Refresh)、location.replace(location)等,Javascript页面自动刷新、跳转,如每隔多少秒刷新一次页面.
window.location.href方式用于跳转到指定页面地址,location.replace将目前浏览器的地址替换掉,调用这个方法的网页,将不会被写入浏览记录。
wx.switchTab(Object object)这里的tabBar是底下的导航栏指定的页面,跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面;wx.reLaunch(Object object)基础库 1.1.0 开始支持,低版本需做兼容处理。
route-link是在html中静态定义的,也可以在代码中动态跳转:注意绝对不能写href=,这样执行click跳转后,又会执行href跳转到当前页面push也可以直接使用path:
Angular中每个页面的显示都需要三个要素:页面的代码,控制器和页面的URL;当要在同一个页面上呈现不同的视图时,这就需要配置路由啦;angular.js已经为我们封装了一个独立的路由工具ng-route;ng-route是靠URL来改变显示的视图的
最近做的移动端页面在请求成功后要跳转页面,通过location.href实现的跳转。但同事在测试时,安卓机可以成功跳转,苹果IOS确无法成功跳转。
在JavaScript中有好几种方法可以实现页面跳转,重定向到另一个网页,下面本篇文章就来给大家介绍一些使用JavaScript实现页面跳转的方法,希望对大家有所帮助。
想进入userManage页面,但是由于没有登录,系统是不会让你进入这个页面,之后会被定向到login页面。但是在登录之后,认为你有这个权限了,就需要重新定向到userManage页面
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!