怎样去除vue项目中的#——历史模式

  介绍

这篇文章主要介绍了怎样去除vue项目中的#——历史模式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获、下面让小编带着大家一起了解一下。

使用vue-cli搭建的环境,在配置好路由之后,可以看到下面的情况:

怎样去除vue项目中的#——历史模式”>,,</p> <p>但是不难发现#的出现真的很丑陋,并且也不知道这是什么作用? </p> <p>所以就去堆栈溢出上搜索了,果然还有~,看来堆栈溢出是真的强大,你在项目中遇到的问题实际上在所以上都已经被问过并且解决了,这不:,</p> <p> <img src=

这是最高票的回答,即在vue2中将模式模式设置为历史,试过之后确实奏效!

但是知道这样可以解决问题,却不知道为什么,这是不行的,随着连接,我们看到了文档。

所以这篇文章也就是引申到文档的理解了,大家可以直接去看文档。

对于vue开发的单页面应用,我们在切换不同的页面的时候,可以发现html永远只有一个,这也真是称之为单页面的原因,而vue-router默认散列模式,使用URL的散列来模拟一个完整的URL,于是当URL改变时,页面不会重新加载。因为对于正常的页面来说,更换URL一定是会导致页面的更换的,而只有更换URL中的查询字符串和散列值得时候才不会重新加载页面。这里也就是这个道理。

但是#这种形式真的很丑!,所以,如果不想要,可以使用路由历史的模式! ! !这种模式充分利用了历史。pushState API来完成URL的跳转而不需要重新加载页面。

const  router =, new  VueRouter ({   模式:大敌;& # 39;历史# 39;   ,路线:[…]   })

使用这种模式之后,就没有#了,而是可以像使用正常的url进行访问了。

不过这种模式要玩好,还需要后台配置支持。因为我们的应用是个单页客户端应用,如果后台没有正确的配置,当用户在浏览器直接访问http://oursite.com/user/id就会返回404,这就不好看了。

所以呢,你要在服务端增加一个覆盖所有情况的候选资源:如果url匹配不到任何静态资源,则应该返回同一个索引。html页面,这个页面就是你应用依赖的页面。

注意:目前我所做的项目的后端没有支持此种方式,所以还是先使用#的方式进行开发。

警告

给个警告,因为这么做以后,你的服务器就不再返回404错误页面,因为对于所有路径都会返回指数。html文件。为了避免这种情况,你应该在Vue应用里面覆盖所有的路由情况,然后在给出一个404页面。

const  router =, new  VueRouter ({   模式:大敌;& # 39;历史# 39;   ,路线:[   ,{,路径:& # 39;* & # 39;,,组件:,NotFoundComponent }   ,)   })

或者,如果你是用节点。js作后台,可以使用服务端的路由来匹配的URL,当没有匹配到路由的时候返回404年,从而实现退。

感谢你能够认真阅读完这篇文章,希望小编分享的“怎样去除vue项目中的#——历史模式”这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

怎样去除vue项目中的#——历史模式