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 相关文章推荐
juqery 学习之五 文档处理 插入
Feb 11 Javascript
设置iframe的document.designMode后仅Firefox中其body.innerHTML为br
Feb 27 Javascript
解决jquery操作checkbox火狐下第二次无法勾选问题
Feb 10 Javascript
Javascript单元测试框架QUnitjs详细介绍
May 08 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
Mar 31 Javascript
又一枚精彩的弹幕效果jQuery实现
Jul 25 Javascript
jQueryUI Sortable 应用Demo(分享)
Sep 07 jQuery
深入理解Node内建模块和对象
Mar 12 Javascript
Vue中使用create-keyframe-animation与动画钩子完成复杂动画
Apr 09 Javascript
js对象数组和对象的使用实例详解
Aug 27 Javascript
在Angular项目使用socket.io实现通信的方法
Jan 05 Javascript
Vue详细的入门笔记
May 10 Vue.js
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
Ajax PHP分页演示
2007/01/02 PHP
手把手教你使用DedeCms的采集的图文教程
2007/03/11 PHP
laravel获取不到session的三种解决办法【推荐】
2018/09/16 PHP
关于jQuery $.isNumeric vs. $.isNaN vs. isNaN
2013/04/15 Javascript
使用js获取地址栏中传递的值
2013/07/02 Javascript
使用jquery中height()方法获取各种高度大全
2014/04/02 Javascript
一个简单的jQuery插件ajaxfileupload.js实现ajax上传文件例子
2014/06/26 Javascript
JS点击链接后慢慢展开隐藏着图片的方法
2015/02/17 Javascript
js调用父框架函数与弹窗调用父页面函数的简单方法
2016/11/01 Javascript
浅谈js script标签中的预解析
2016/12/30 Javascript
js实现网页定位导航功能
2017/03/07 Javascript
layui从数据库中获取复选框的值并默认选中方法
2018/08/15 Javascript
详解swiper在vue中的应用(以3.0为例)
2018/09/20 Javascript
nodejs实现获取本地文件夹下图片信息功能示例
2019/06/22 NodeJs
[01:09:24]Ti4开幕式
2014/07/19 DOTA
Linux下使用python调用top命令获得CPU利用率
2015/03/10 Python
Python中使用gzip模块压缩文件的简单教程
2015/04/08 Python
解析Python编程中的包结构
2015/10/25 Python
使用python批量化音乐文件格式转换的实例
2019/01/09 Python
python实现桌面壁纸切换功能
2019/01/21 Python
在python中利用opencv简单做图片比对的方法
2019/01/24 Python
Python3中_(下划线)和__(双下划线)的用途和区别
2019/04/26 Python
python小程序实现刷票功能详解
2019/07/17 Python
django框架创建应用操作示例
2019/09/26 Python
Django-migrate报错问题解决方案
2020/04/21 Python
The Beach People美国:澳洲海滨奢华品牌
2018/07/05 全球购物
ECOSUSI官网:女式皮革背包
2019/09/27 全球购物
学院书画协会部门岗位职责
2013/12/01 职场文书
业务员自荐信范文
2014/04/20 职场文书
经贸日语专业个人求职信范文
2014/04/29 职场文书
大二学生学年自我鉴定
2014/09/12 职场文书
房屋出租委托书格式
2014/09/23 职场文书
党的群众路线领导班子整改方案
2014/09/27 职场文书
2014年手术室工作总结
2014/11/26 职场文书
2015年路政工作总结
2015/05/22 职场文书
SQL实现LeetCode(197.上升温度)
2021/08/07 MySQL