Vue学习:_history与hash模式

路由器的两种工作模式+项目上线的基本流程

hash模式

前面案例的地址栏目有#号实际上

路径开始#开始到末尾都是路径里面的hash值,特点:不会随http请求发给服务器

启动服务器http://localhost:5000/students

node .\server1.js

启动hash模式不会影响访问路径

不是hash模式会影响

_history模式

在路由配置规则里面改 配置项mode 默认的是hash 改成history

    mode:'history'

没有了#号了

#兼容性好 /美观

项目上线流程

将所有写的东西打包--vue变成 .html .js .css

我们目前使用的都是npm run serve

现在要换成build ==》npm run bulid

npm run build

生成了新的文件

map是webpack的映射文件

双击不能代开,打包的文件需要放在服务器上,进行一个部署才能运行

创建简单服务器

新建文件夹

npm init -y

创建服务器

//导入express
const express=require('express')
//创建web服务器
const app=express()

//监听客户端的GET请求和POST请求,并向客户端响应具体内容
app.get('/person',function(req,res){
    res.send(
        {"name":"zj","age":66,"gender":"男"}
         )
})


//启动服务器.lisen(端口号,(启动成功职之后的回调函数)) 端口号是80可以省略
app.listen(5007,()=>{
    console.log('如果启动成功,则客户端为http://127.0.0.1:5007 ,打印这一行输出')
})

创建静态资源目录,使用express插入静态资源

可以进行访问

将前面的dist文件的内容全部放入静态资源的文件,如果是index.html可以省略

点击可以--不发送网络请求,影响的history模式

刷新了history就变成资源请求了,但是hash就没影响了

解决办法:后端配合--使用正则匹配 或者使用中间件npm i connect-history-api-fallback 解决history404

npm i connect-history-api-fallback

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 的区别是什么? 回答:Vue 的路由模式有两种,一种是 hash 模式,另一种是 history 模式hash 模式的 URL 中带有 # 符号,而 history 模式则不带。hash 模式的优点是兼容性好,可以兼容不支持 HTML5 History API 的浏览器,缺点是 URL 不太美观。history 模式的优点是 URL 美观,缺点是需要服务器端支持,否则会出现 404 错误。 ### 回答2: vue提供了两种路由模式hash模式和history模式hash模式是指URL中带有一个 # 号,并且所有的路由地址都是基于这个 # 号后面的部分。例如,URL中的路径可以是"例子.com/#/home"。hash模式的优点是兼容性较好,所有浏览器都支持。另外,hash模式在前后端分离开发中比较方便,因为路由地址的变化不会被后端服务器识别到,可以避免出现404错误。但是,hash模式的缺点是URL中会有一个#号,显得不太美观,对于SEO也不友好。 history模式是利用了HTML5的history API来实现的,它的URL是没有#号的,例如"例子.com/home"。history模式的优点是URL较为美观,对于用户体验来说更加友好。此外,history模式还可以利用history.pushState()和history.replaceState()等API来对浏览器历史记录进行管理。但是,history模式的缺点是兼容性较差,只有较新版的浏览器才支持history API,同时在使用history模式时需要后端服务器的支持,因为对于后端服务器来说,任何路由都指向同一个index.html文件,需要使用后端路由重定向来解决这个问题。 总之,hash模式和history模式都有各自的优缺点,选择使用哪种模式取决于具体的项目需求和兼容性要求。 ### 回答3: Vue.js是一种用于构建用户界面的开源JavaScript框架。它提供了许多功能和工具,可以帮助开发人员构建高效、灵活和可扩展的应用程序。Vue具有两种路由模式:哈希模式hash mode)和历史模式(history mode)。 哈希模式Vue默认使用的路由模式。在哈希模式中,URL会被修改为包含一个哈希值(#)的格式。例如,如果我们要访问“/home”页面,URL将变为“/#/home”。这种模式的一个优点是它可以在不同的浏览器之间正常工作,因为哈希值只存在于客户端而不会发送到服务器。它还简化了部署和配置过程,因为不需要服务器任何额外的配置就可以支持Vue路由。但是,这种模式的缺点是URL看起来不太友好,可能会给用户造成困惑。 历史模式Vue的另一种路由模式。在历史模式中,URL不再包含哈希值,而是直接使用正常的URL格式。例如,访问“/home”页面的URL将变为“/home”。这种模式使URL看起来更加友好和自然,并且可以使用服务器路由来处理URL。但是,它需要服务器配置来支持Vue路由,并且在部署和配置时可能会更复杂。 选择使用哈希模式还是历史模式取决于特定应用程序的需求和情况。如果您正在构建一个单页应用,并且不需要服务器配置和正常的URL格式,那么哈希模式可能是更简单和适合的选择。然而,如果您需要更友好和自然的URL,并且需要服务器路由来处理URL,那么历史模式可能更适合。无论选择哪种模式Vue都提供了简单易用且功能强大的路由功能,可以帮助开发人员构建出色的应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值