vue在App.vue文件中监听路由变化刷新页面操作


Posted in Javascript onAugust 14, 2020

在路由跳转时,会出现页面需要重新刷新一遍才能获取数据加载页面,这时添加一个监听器,如果跳转到页面刷新一次。

export default {
 name: 'App',
 provide(){
 return{
  reload:this.reload
 }
 },
 data(){
 return {
  isRouterAlive:true,
 }
 },
 //监听器
 watch: {
 // 方法1
 '$route' (to, from) { //监听路由是否变化
  // console.log(999)
  if(to.path == "/"){ //跳转到哪个页面
  location.reload()
  }
 },
 },
 methods:{
 reload(){
  this.isRouterAlive = false;
  this.$nextTick(function () {
  this.isRouterAlive = true
  });
 },
 },
}

补充知识:vue监听路由的改变和监听页面的刷新与离开

要分清两者的区别。

首先是监听页面的刷新与离开,此时相当于直接在这个网页中按了刷新,如果是webapp则是离开这个app而不是切换路由!

如果是用js的特性监测,则是不仅可以页面的刷新与离开,还能切换路由。注意当keepalive时即使切换了路由也无效。

在script中直接增加监听器监视beforeunload:

//监视如果页面离开
    created() {
      window.addEventListener('beforeunload', this.updateHandler)
    },
    beforeDestroy() {
      this.finalItemDetail(); // 自己要进行的操作
    },
    destroyed() {
      window.removeEventListener('beforeunload', this.updateHandler)
    },

然后methods中添加finalItemDetail和updateHandler方法:

updateHandler() {
        this.finalItemDetail()
      },
      finalItemDetail() {
        console.log('刷新或关闭');
      },

如果想监听某个特定的页面的离开,比如我现在在/index下,现在去了/index/001下面,就可以在watch中监听路由的变化,前提是实用vue-router。

如果是简单的判断路由变化可以用注释掉的,直接执行clear方法(自己定义在methods中)

但是注意这个只能监听自己子路由的变化!

watch: {
      // 如果路由有变化,会再次执行clear方法
      // "$route": "clear",
      $route(to , from){
        console.log( to.path, from.path );
        this.clear(to.path);
      }
    },

然后我还额外做了个判断:

clear(path) {
        if(path!="/item/item01/evaluate")
          console.log("从这个页面离开了");
        this. active=0;
      },

以上这篇vue在App.vue文件中监听路由变化刷新页面操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
在网页中屏蔽快捷键
Sep 06 Javascript
jQuery 表单验证扩展(四)
Oct 20 Javascript
js里怎么取select标签里的值并修改
Dec 10 Javascript
Jquery+CSS3实现一款简洁大气带滑动效果的弹出层
May 15 Javascript
ext前台接收action传过来的json数据示例
Jun 17 Javascript
JavaScript字符串对象substr方法入门实例(用于截取字符串)
Oct 16 Javascript
了不起的node.js读书笔记之node的学习总结
Dec 22 Javascript
js实现浏览器窗口大小被改变时触发事件的方法
Feb 02 Javascript
自动适应iframe右边的高度
Dec 22 Javascript
js清除浏览器缓存的几种方法
Mar 15 Javascript
vue+mousemove实现鼠标拖动功能(拖动过快失效问题解决方法)
Aug 24 Javascript
Echarts之悬浮框中的数据排序问题
Nov 08 Javascript
解决vue项目中某一页面不想引用公共组件app.vue的问题
Aug 14 #Javascript
在vue中封装方法以及多处引用该方法详解
Aug 14 #Javascript
JS+css3实现幻灯片轮播图
Aug 14 #Javascript
浅谈vue获得后台数据无法显示到table上面的坑
Aug 13 #Javascript
vue 解决data中定义图片相对路径页面不显示的问题
Aug 13 #Javascript
解决vue net :ERR_CONNECTION_REFUSED报错问题
Aug 13 #Javascript
vue用elementui写form表单时,在label里添加空格操作
Aug 13 #Javascript
You might like
PHP调用VC编写的COM组件实例
2014/03/29 PHP
Javascript与PHP验证用户输入URL地址是否正确
2014/10/09 PHP
php解析字符串里所有URL地址的方法
2015/04/03 PHP
CodeIgniter钩子用法实例详解
2016/01/20 PHP
thinkphp实现把数据库中的列的值存到下拉框中的方法
2017/01/20 PHP
PHP正则匹配反斜杠'\'和美元'$'的方法
2017/02/08 PHP
PHP defined()函数的使用图文详解
2019/07/20 PHP
JavaScript 编写匿名函数的几种方法
2010/02/21 Javascript
兼容IE和Firefox火狐的上下、左右循环无间断滚动JS代码
2013/04/19 Javascript
JS动态添加与删除select中的Option对象(示例代码)
2013/12/25 Javascript
用js代码和插件实现wordpress雪花飘落效果的四种方法
2014/12/15 Javascript
windows下安装nodejs及框架express
2015/08/07 NodeJs
JS实现隐藏同级元素后只显示JS文件内容的方法
2016/09/04 Javascript
详解vue-router和vue-cli以及组件之间的传值
2017/07/04 Javascript
微信小程序实现倒计时60s获取验证码
2020/04/17 Javascript
Vuejs 实现简易 todoList 功能 与 组件实例代码
2018/09/10 Javascript
Python基于twisted实现简单的web服务器
2014/09/29 Python
Windows平台Python编程必会模块之pywin32介绍
2019/10/01 Python
python定时任务 sched模块用法实例
2019/11/04 Python
Python猴子补丁Monkey Patch用法实例解析
2020/03/23 Python
如何使用PyCharm将代码上传到GitHub上(图文详解)
2020/04/27 Python
Python Django中间件使用原理及流程分析
2020/06/13 Python
HTML5视频支持检测(检查浏览器是否支持视频播放)
2013/06/08 HTML / CSS
高级运动鞋:GREATS
2019/07/19 全球购物
世界各地的当地人的食物体验:Eatwith
2019/07/26 全球购物
serialVersionUID具有什么样的特征
2014/02/20 面试题
我的祖国演讲稿
2014/05/04 职场文书
团日活动总结书格式
2014/05/08 职场文书
公司委托书怎么写
2014/08/02 职场文书
违纪检讨书
2015/01/27 职场文书
女方家长婚礼致辞
2015/07/27 职场文书
初中班主任工作随笔
2015/08/15 职场文书
大学班干部竞选稿
2015/11/20 职场文书
古诗之爱国古诗5首
2019/09/20 职场文书
导游词之珠海轮廓
2019/10/25 职场文书
JavaScript利用html5新方法操作元素类名详解
2021/11/27 Javascript