前端路由的两种主流实现方式和原理

2018-05-09  本文已影响0人  一座被占用

路由历史

    什么是路由?路由就是根据不同的url地址展示不同的内容或页面

    早期的路由都是后端直接根据url来reload页面实现的,即后端控制路由(目前很多小网站也是如此)

    后来页面越来越复杂,服务器压力越来越大,随着ajax(异步刷新技术)的出现,页面实现非reload就能刷新数据,让前端也可以控制url自行管理,前端路由由此而生。

单页面应用的实现,就是因为前端路由

1.Pjax(PushState + Ajax)

原理:利用ajax请求替代了a标签的默认跳转,然后利用html5中的API修改了url

API:history.pushState 和 history.replaceState

两个API都会操作浏览器的历史记录,而不会引起页面的刷新,pushState会增加一条新的历史记录,而replaceState则会替换当前的历史记录

例子:

2.Hjax(Hash + Ajax)

原理:url中常会出现 # ,一可以表示锚点(如回到顶部按钮的原理),二是路由里的锚点(hash),Web服务并不会解析hash,也就是说 # 后的内容 Web 服务都会自动忽略,但是JavaScript是可以通过window.location.hash读取到的,读取到路径加以解析之后可以响应不同路径的逻辑处理。

hashchange事件(监听hash变化触发的事件),当用window.location处理哈希的改变时不会重新渲染页面,而是当作新页面加到历史记录中,这样我们跳转页面就可以再hashchange事件中注册 ajax 从而改变页面内容

网站1


一知半解,实际上还没有动手操作过。

上一篇下一篇

猜你喜欢

热点阅读