聊聊vue的两种路由模式(哈希和历史)
时间:2023-04-12 19:36
路由器分别有两种模式:一种是 这两种模式各有自己的优势,但他们的使用区别,却多多少少都会在面试当中被问到 今天就一起来学习下 如下所示 特点: 页面刷新时,会停留在当前页面,不会重新加载 如果觉得 这两种方式的使用都是没啥问题的,如果你在意浏览器 如果你想 但是:在 而 如: 如果你想要支持 在服务端增加一个覆盖所有情况的时候的候选资源,如果 如果出现404,容易让用户觉得这是一个Bug 解决这个问题:如果你用的是 如果是 如下这段简易的 启动后端服务执行命令 把前端打包生成的 我们的前端使用的 也就是说,整个应用只有一个完整的页面,同时,点击页面中的导航链接,不会刷新页面,只会是页面的局部更新 而我们页面中的数据,往往需要通过 现在开发的新项目,都是前后端分离,基本上都是单页面应用 前端路由,有两种模式,一种是 否则部署到线上,一刷新页面,会出现 (学习视频分享:vuejs入门教程、编程基础视频) 以上就是聊聊vue的两种路由模式(哈希和历史)的详细内容,更多请关注Gxl网其它相关文章!hash
模式、另一种是history
模式,在使用vue-cli
以及vue-router
默认搭建的vue
项目,如果不做特殊的配置,默认就是hash
模式哈希模式(hash)
vue-router
默认hash
模式,使用url
的哈希(hash
)来模拟一个完整的URL
,当URL
改变时,页面不会重新加载。【相关推荐:vuejs视频教程、web前端开发】http://localhost/#home
#
号后面的参数不会传送给服务器,兼容性好,不会作为路径的一部分发送给服务器,也就是它不会包括在HTTP
请求体中,对后端完全没有影响,只是我们前端同学自己玩hash
路径很丑,不简洁,我们可以用路由的history
模式,这种模式充分利用history.pushState API
或replaceState
,来完成,url
跳转而无需重新加载页面历史模式
history
模式:在实例化配置对象中添加mode
模式,值为history
就可以了的经过改造后,hash
模式就会变成history
模式const router = new VueRouter({ mode: 'history', routes: [...]})
url
的颜值,#
符号掺杂在url
里看起来确实有些不优雅url
更好看,那么就使用history
模式hash
模式下,使用hash
符号之前的内容会被包含在请求体中,#
号后面的不会发送给服务器history
模式下,前端的URL
必须和实际向后端发起请求的URL
保持一致https://itclan.cn/fontend/id
,如果后端缺少没有对/fontend/id
的路由处理,那么它将返回404
错误history
模式,那么需要后端同学支持,想要彻底解决404的问题,需要与后端同学协商,因为需要后端与前端路由做匹配url
匹配不到任何静态资源,应该返回一个首页页面如何解决前台刷新页面404问题
Node
做后端服务,那么在Node
后台中可以加入一个中间件比如:connect-history-api-fallback
即可解决这种404问题java
或php
,找后端同学,让后端路由与前端路由做匹配,或是用Ngnix
做中间代理Node
服务代码,可以命名为server.js
,同时安装express
以及connect-history-api-fallback
中间件node server.js
const express = require('express');const history = require('connect-history-api-fallback')const app = express()app.use(history())app.use(express.static(__dirname+'/static'));app.listen(5005,(err)=> { if(!err)consle.log('服务器启动成功了')})
dist
文件内的代码,放到static
中,通过这一操作,即可解决刷新页面,404
的问题对单页面spa的应用理解
vue-router
中的两种模式,就是单页面应用,整个应用只有一个router
路由器,是可以通过$router
属性获取到ajax
请求来获取总结
hash
模式,另一种是history
模式,其中hash
模式是默认模式,#
后面的不会发送给服务端,不会重新刷新加载页面,而history
模式,url
虽然比较好看,但是想要完整支持,需要后端同学提供支持,后端路由与前端的路由需要做匹配404
的问题