Vue-router
1. history与hash区别
前端路由的核心,就在于 —— 改变视图的同时不会向后端发出请求。
- hash —— 即地址栏 URL 中的 # 符号(此 hash 不是密码学里的散列运算)。比如这个 URL:http://www.abc.com/#/hello,hash 的值为 #/hello。它的特点在于:hash 虽然出现在 URL 中,但不会被包括在 HTTP 请求中,对后端完全没有影响,因此改变 hash 不会重新加载页面。
- history —— 利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法。(需要特定浏览器支持)这两个方法应用于浏览器的历史记录栈,在当前已有的 back、forward、go 的基础之上,它们提供了对历史记录进行修改的功能。只是当它们执行修改时,虽然改变了当前的 URL,但浏览器不会立即向后端发送请求。
因此可以说,hash 模式和 history 模式都属于浏览器自身的特性,Vue-Router 只是利用了这两个特性(通过调用浏览器提供的接口)来实现前端路由.
hash,此处我们在任何网址后面输入#abc刷新,页面都不会跳转的,history则相反,没有对应的页面就是出现404
如何使用中间件 解决history mode 在服务端的问题,让其走客户端路由,不走服务端?
-
安装相关包
-
var history = require(‘connect-history-api-fallback’);
-
app.use(history());