vue 项目地址去掉 #的方法


Posted in Javascript onOctober 20, 2018

vue-router 设置 history 模式

vue 项目往往会搭配 vue-router 官方路由管理器,它和 vue.js 的核心深度集成,让构建单页面应用变得易如反掌。vue-router 默认为 hash 模式,使用 URL 的 hash 来模拟一个完整的 URL,所以当 URL 改变时,页面不会重新加载,只是根据 hash 来更换显示对应的组件,这就是所谓的单页面应用。

但是使用默认的 hash 模式时,浏览器 URL 地址中会有一个 # ,这跟以往的网站地址不太一样,可能也会让大部分人不习惯,甚至觉得它很丑。

想要去掉地址中的 # 也不难,只要更换 vue-router 的另一个模式 history 模式即可做到。

vue 项目地址去掉 #的方法

history 模式

当你使用 history 模式时,URL 就变回正常又好看的地址了,和大部分网站地址一样,例如: http://zhengchang.com/name/id

不过,这种模式有个坑,不仅需要前端开发人员将模式改为 history 模式,还需要后端进行相应的配置。如果后端没有正确的配置好,当你访问你的项目地址时,就会出现 404 ,这样可就更不好看了。

官方给出了几种常用的后端配置例子:

Apache

vue 项目地址去掉 #的方法 

nginx

vue 项目地址去掉 #的方法 

原生 Node.js

vue 项目地址去掉 #的方法

Internet Information Services (IIS)

vue 项目地址去掉 #的方法

因为我的项目后端服务是 IIS ,所以就着重分享一下 IIS 的相关配置 。

vue 项目地址去掉 #的方法

IIS 后端配置

首先,前端将 vue-router 模式修改为 history 模式,开发完成并打包后,将文件部署到站点。站点的根目录会有一些相关配置文件,这些后端人员会很清楚,前端开发只需要告诉后端人员如何写去掉 # 的配置文件。

在站点的根目录创建一个 web.config 文件,内容如上图所示。起到关键作用的是 rewrite 标签中的代码:

  • rule 标签:代表定义的一条规则。
  • match 标签:你的规则是什么要求,url 属性内容就是要求(正则表达式)。
  • action 标签:type 属性为 Rewrite(重写),url 属性为目标。意思是:如果满足 match 标签中 url 属性的正则,就执行此配置(将符合match标签url要求的地址,重写为action标签中url属性的地址)。

这个配置就和重定向一样,将符合你要求的地址,重定向为你想要的地址。下面是我的项目中 IIS 的配置:

我的要求是,除了 "api" 或者 "token" 开头的地址,全部重定向为 " / " ,因为我的接口地址是 api 和 token 开头的,所以接口地址不能变。

vue 项目地址去掉 #的方法

api 接口

vue 项目地址去掉 #的方法

token 接口

然后服务端设置的是默认显示目录下的 index.html ,而这个 index.html 文件就是前端打包后生成的 html 文件。网站打开了 html 文件,执行对应脚本,就会按照你的路由设置显示对应的组件内容,浏览器地址中的 # 也被替换掉了。

还有一个 rule 标签是配置我的图片路径的。

图片在开发环境中,都按照对应的组件,分类放到不同的文件夹中,例如:home 组件中的 banner 图,路径是 “ assets/home/banner.png ”。

我的项目打包后,生成了 index.html 和 static 文件夹,js、css、img等文件夹都在 static 中。所有的图片全都放在“ /static/img/ ”下面,图片路径也会自动更改为“ ./static/img/ ”。

我不希望图片路径重定向为“ / ”,所以规则就是:将符合“ ./static/img/name.png ”重定向为“ /static/img/name.png ”。

vue 项目地址去掉 #的方法

静态图片路径

配置里的最难的可能是那个正则表达式,根据不同的需求配置不同的正则表达式,搞定正则就大功告成了!

总结

以上所述是小编给大家介绍的vue 项目地址去掉 #的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery中prop()方法和attr()方法的区别浅析
Sep 06 Javascript
常用的JavaScript模板引擎介绍
Feb 28 Javascript
Bootstrap简单表单显示学习笔记
Nov 15 Javascript
微信小程序开发之Tabbar实例详解
Jan 09 Javascript
JavaScript解析任意形式的json树型结构展示
Jul 23 Javascript
jQuery使用zTree插件实现可拖拽的树示例
Sep 23 jQuery
Vue导出json数据到Excel电子表格的示例
Dec 04 Javascript
基于Vue的ajax公共方法(详解)
Jan 20 Javascript
详解vue-router数据加载与缓存使用总结
Oct 29 Javascript
vue实现双向绑定和依赖收集遇到的坑
Nov 29 Javascript
JSON基本语法及与JavaScript的异同实例分析
Jan 04 Javascript
vue自定义switch开关组件,实现样式可自行更改
Nov 01 Javascript
VUE-cli3使用 svg-sprite-loader
Oct 20 #Javascript
vuex2中使用mapGetters/mapActions报错的解决方法
Oct 20 #Javascript
Vue项目pdf(base64)转图片遇到的问题及解决方法
Oct 19 #Javascript
使用pkg打包Node.js应用的方法步骤
Oct 19 #Javascript
简化版的vue-router实现思路详解
Oct 19 #Javascript
vue中el-upload上传图片到七牛的示例代码
Oct 19 #Javascript
浅析vue-router原理
Oct 19 #Javascript
You might like
用phpmyadmin更改mysql5.0登录密码
2008/03/25 PHP
php 读取shell管道传输过来的内容
2010/03/01 PHP
强烈声明: 不要使用(include/require)_once
2013/06/06 PHP
php上传图片之时间戳命名(保存路径)
2014/08/15 PHP
php禁止某ip或ip地址段访问的方法
2015/02/25 PHP
基于laravel制作APP接口(API)
2016/03/15 PHP
js获取单元格自定义属性值的代码(IE/Firefox)
2010/04/05 Javascript
前端开发必须知道的JS之原型和继承
2010/07/06 Javascript
跟我学习javascript的执行上下文
2015/11/18 Javascript
vue实现列表的添加点击
2016/12/29 Javascript
微信小程序 石头剪刀布实例代码
2017/01/04 Javascript
zTree树形菜单交互选项卡效果的实现方法
2017/12/25 Javascript
Angular2之二级路由详解
2018/08/31 Javascript
webpack+vue-cli项目中引入外部非模块格式js的方法
2018/09/28 Javascript
使用form-create动态生成vue自定义组件和嵌套表单组件
2019/01/18 Javascript
js模拟F11页面全屏显示
2019/09/17 Javascript
jquery 回调操作实例分析【回调成功与回调失败的情况】
2019/09/27 jQuery
vue 项目打包时样式及背景图片路径找不到的解决方式
2019/11/12 Javascript
JS实现拖动模糊框特效
2020/08/25 Javascript
python通过exifread模块获得图片exif信息的方法
2015/03/16 Python
pandas中去除指定字符的实例
2018/05/18 Python
Python读取Excel表格,并同时画折线图和柱状图的方法
2018/10/14 Python
python自动化生成IOS的图标
2018/11/13 Python
Selenium元素定位的30种方式(史上最全)
2020/05/11 Python
python入门:argparse浅析 nargs='+'作用
2020/07/12 Python
python openpyxl模块的使用详解
2021/02/25 Python
香港时尚女装购物网站:ZAFUL
2017/07/19 全球购物
Superdry极度干燥美国官网:英国制造的服装品牌
2018/11/13 全球购物
全陪导游欢迎词
2014/01/17 职场文书
国庆宣传标语
2014/06/30 职场文书
酒店餐厅2014重阳节活动策划方案
2014/09/16 职场文书
声乐专业大学生职业生涯规划书:理想的未来需要自己去打造
2014/09/20 职场文书
检讨书格式
2015/05/07 职场文书
给男朋友的道歉短信
2015/05/12 职场文书
Golang表示枚举类型的详细讲解
2021/09/04 Golang
SpringCloud项目如何解决log4j2漏洞
2022/04/10 Java/Android