一、前端路由开发的发展过程
1.1、后端路由阶段
早期的网站开发整个HTML页面都是由服务器来渲染的。服务器直接生成渲染好的HTML页面, 返回给客户端进行展示。
一个网站这么多页面,服务器如何处理呢?
没有页面有自己对应的URL,当URL发送到服务器, 服务器会通过正则对该URL进行匹配, 最后交给一个Controller进行处理。Controller进行各种处理, 最终生成HTML或者数据, 返回给前端。这就完成了一个IO操作(HTTP请求)。这就是后端路由。
后端路由的缺点
整个页面的模块由后端人员来编写和维护的,HTML代码和数据以及对应的逻辑会混在一起, 编写和维护都是非常糟糕的事情。
1.2、前端路由阶段
前后端分离阶段
随着Ajax的出现, 有了前后端分离的开发模式。后端只提供API来返回数据, 前端通过Ajax获取数据, 并且可以通过JavaScript将数据渲染到页面中。
这样做最大的优点就是前后端责任的清晰, 后端专注于数据上, 前端专注于交互和可视化上。并且当移动端(iOS/Android)出现后, 后端不需要进行任何处理, 依然使用之前的一套API。
单页面富应用阶段
其实SPA(single page web application)最主要的特点就是在前后端分离的基础上加了一层前端路由;也就是前端来维护一套路由规则。
前端路由的核心是:改变URL,但是页面不进行整体的刷新。
二、SPA核心:URL改变,页面不刷新的原理
在单页应用中,前端路由根据不同的 url 显示不同的内容。想要知道这是如何做到的,首先得了解浏览器提供的两大 API:
window.location
location.href
loc