vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法


Posted in Javascript onJanuary 25, 2018

解决vue-router嵌套路由(子路由)在history模式下刷新无法渲染页面的问题,具体内容如下

一. 异常描述

本来使用的是vue-router的hash模式,但是hash模式下url需要带“#”符号,不仅看起来不舒服,而且有些场景下是会破坏路由中的"#"(微信分享页面就会把"#"后边的内容处理掉),所以就需要使用history模式,然后就让后端改下nginx配置:

location / { try_files $uri $uri/ /index.html; }

vue-router使用history模式+使用嵌套路由:

const router = new Router({
 mode: 'history',
 routes: [
  {
   path: '/',
   component: mall,
   name: 'mall'
  },
  ……

  //我的银行卡
  {
   path: '/myCard',
   meta: { requireAuth: true },
   component: myCard,
   name: 'myCard',
   children:[
   { path:'', component: card},
   { path:'add', component: add}
   ]
  }
   ……
 ]
})

访问路由和嵌套路由页面,显示正常,但是刷新页面的时候,嵌套路由页面就出异常了:

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

页面样式全乱了,看下页面请求加载的静态文件,所有静态文件都是404;

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

二. 异常解析

1. 看下官方文档对嵌套路由的说明:

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

2. 再看之前的异常页面,看来我们的父路由成了根目录了看下文件路径了:

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

3. 看下我们引入这些异常文件,是在index.html文件中直接引用的,也就是在根路径下引入的。之前的hash模式下,根路径是不会变的,所以我们在index.html文件中直接引入这些静态文件,是可行的,但是使用history模式后,根路径就不固定了。那么这种引入方式就不可行了,所以才造成了上边出现的页面无法渲染的问题:

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

三. 解决问题

这里有点尴尬,先考虑的主Vue中以Import的方式引入静态样式文件,的确可行,但是最后发现,直接修改index.html文件中的静态文件引入路径就OK了:

修改前:

<script src="./static/js/stomp.js"></script>

修改后

<script src="/static/js/stomp.js"></script>

四. 原理

./ 是指用户所在的当前目录(相对路径);

/ 是指根目录(绝对路径,项目根目录),也就是项目根目录;

对于hash模式,根路径是固定的,就是项目的根目录,但是history模式下,以/开头的嵌套路径会被当作根路径,所以使用“./”引入文件,就会找不到文件了,因为文件本身就是在项目根目录下的,并不在嵌套路径这个目录下。

总结,无论hash模式还是history模式,可以直接使用“/”从项目根目录引入静态文件。

PS:之前一段时间就遇到过这个问题,百度了好久,发现很少有人问这个问题,有一个也没人回答。也问了好些前端大神,还是没能解决这个问题。也许是平时写惯了“./” 和“../”这些开头的路径了吧,并没有注意到静态文件引入方式的问题,折腾了好些方法,最后很尴尬的发现,其实问题很简单,只是对框架的底层了解不透彻罢了!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
表格 隔行换色升级版
Nov 07 Javascript
JQuery下的Live方法和$.browser方法使用代码
Jun 02 Javascript
基于jQuery捕获超链接事件进行局部刷新代码
May 10 Javascript
HTML页面弹出居中可拖拽的自定义窗口层
May 07 Javascript
用Angular实时获取本地Localstorage数据,实现一个模拟后台数据登入的效果
Nov 09 Javascript
bootstrap中模态框、模态框的属性实例详解
Feb 17 Javascript
JavaScript实现的浏览器下载文件的方法
Aug 09 Javascript
Vue-Router进阶之滚动行为详解
Sep 13 Javascript
微信小程序实现即时通信聊天功能的实例代码
Aug 17 Javascript
turn.js异步加载实现翻书效果
Jul 25 Javascript
vue实现简单学生信息管理
May 30 Javascript
vue+element使用动态加载路由方式实现三级菜单页面显示的操作
Aug 04 Javascript
vue通过路由实现页面刷新的方法
Jan 25 #Javascript
jQuery zTree搜索-关键字查询 递归无限层功能实现代码
Jan 25 #jQuery
JavaScript实现职责链模式概述
Jan 25 #Javascript
使用Ajax和Jquery配合数据库实现下拉框的二级联动的示例
Jan 25 #jQuery
解决Jquery下拉框数据动态获取的问题
Jan 25 #jQuery
vue引入新版 vue-awesome-swiper插件填坑问题
Jan 25 #Javascript
vue better-scroll插件使用详解
Jan 25 #Javascript
You might like
在WIN98下以apache模块方式安装php
2006/10/09 PHP
Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解
2017/11/14 PHP
jquery form表单提交插件asp.net后台中文解码
2010/06/12 Javascript
Javascript的常规数组和关联数组对比小结
2012/05/24 Javascript
javascript 通用loading动画效果实例代码
2014/01/14 Javascript
jquery淡化版banner异步图片文字效果切换图片特效
2014/04/08 Javascript
js使用栈来实现10进制转8进制与取除数及余数
2014/06/11 Javascript
JavaScript中的迭代器和生成器详解
2014/10/29 Javascript
JavaScript时间转换处理函数
2015/04/14 Javascript
浅谈javascript事件取消和阻止冒泡
2015/05/26 Javascript
JavaScript中的pow()方法使用详解
2015/06/15 Javascript
js绘制圆形和矩形的方法
2015/08/05 Javascript
AngularJS中transclude用法详解
2016/11/03 Javascript
jquery文字填写自动高度的实现方法
2016/11/07 Javascript
jsonp跨域获取数据的基础教程
2018/07/01 Javascript
微信小程序实践之动态控制组件的显示/隐藏功能
2018/07/18 Javascript
详解Vue结合后台的列表增删改案例
2018/08/21 Javascript
JavaScript实现的拼图算法分析
2019/02/13 Javascript
vue设置一开始进入的页面教程
2019/10/28 Javascript
JQuery常用选择器功能与用法实例分析
2019/12/23 jQuery
Python实现基于HTTP文件传输实例
2014/11/08 Python
Python numpy生成矩阵、串联矩阵代码分享
2017/12/04 Python
Sanic框架异常处理与中间件操作实例分析
2018/07/16 Python
Python Subprocess模块原理及实例
2019/08/26 Python
简单了解python中的f.b.u.r函数
2019/11/02 Python
使用python采集Excel表中某一格数据
2020/05/14 Python
英国知名化妆品网站:Revolution Beauty(原TAM Beauty)
2018/02/28 全球购物
Jimmy Choo美国官网:周仰杰鞋子品牌
2018/06/08 全球购物
黑猩猩商店:The Chimp Store
2020/02/12 全球购物
最美护士演讲稿
2014/08/27 职场文书
教师个人自我剖析材料
2014/09/29 职场文书
2014年人事专员工作总结
2014/11/19 职场文书
干部年终考核评语
2015/01/04 职场文书
婚礼女方父母答谢词
2015/01/04 职场文书
授权协议书范本(3篇)
2019/10/15 职场文书
详解Python小数据池和代码块缓存机制
2021/04/07 Python