浅谈网站无刷新更新技术,基于hash路由的实现。

时间: 2017-10-31阅读: 671标签: 跳转

现在为了提高网站的用户体验,如添加页面切换动画,减少页面加载,很多网站为此都采用了无刷新技术来加载页面内容。目前很多框架都是实现了这一点来开发单页应用,比如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路由来实现页面的无刷新更新页面的。写的很简单,也很丑陋,但是思路就是这样。





fly63.com版权所有,内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权,请与小编联系!情况属实本人将予以删除!

广告合作文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯