详解vue beforeRouteEnter 异步获取数据给实例问题


Posted in Javascript onAugust 09, 2019

场景: vue-router 路由钩子 beforeRouteEnter 可以用来在初始进入页面前,http 异步获取数据 mockData ,预先判断是进入 A 页、还是 B 页,还是留在本页;而如果留在本页的话,还需要在 mounted 根据 mockData 来判断显示哪种状态(可以在本页面实例创建后,重新发起 http 请求获取 mockData ,但是没有必要,造成代码冗余);

执行顺序:

async beforeRouteEnter(to, from, next) {
   let res = await gameData()
   console.log('beforeRouteEnter start');
   next(vm => {
    console.log("vm start")
    vm.is_exchange = res.is_exchange
    vm.is_finish = res.is_finish
   })
 },
 beforeCreate() {
  console.log("beforeCreate start")
 },
 mounted(){
  console.log('mounted start');
  if(this.is_finish){
   this.modalMsg="活动已结束"
   return;
  }
  if(this.is_exchange){
   this.modalMsg="您已兑换奖品"
   return;
  }
 }

打印结果如下:

beforeRouteEnter start

beforeCreate start

mounted start

vm start

由打印结果,我们可以总结 beforeRouteEnter 钩子确实在 vue 实例创建前执行,但是其 next 函数中 vm 回调不是同步执行,而是等到 mounted 执行完之后,才执行 。

症结:因为我们要根据 mockData 中的 is_exchange 和 is_finish 参数来判断决定页面初始状态,此过程需要在 mounted 中执行;但是 mounted 执行时, vm 还未执行,即 mounted 拿不到

is_exchange 和 is_finish 这两个值,这样就造成了冲突;

解决:在 next 中 打印 vm ,发现 vm 就是当前 vue 实例对象,即可以使用 vm 调用所有当前实例的变量和方法;那依次,能否将判断逻辑写入 methods 中一个方法中,使用 vm 来调用呢?

async beforeRouteEnter(to, from, next) {
   let res = await gameData()
   console.log('beforeRouteEnter start');
   next(vm => {
    console.log("vm start")
    vm.is_exchange = res.is_exchange
    vm.is_finish = res.is_finish

    vm.judge();//赋值之后,此处调用判断方法
   })
 },
 beforeCreate() {
  console.log("beforeCreate start")
 },
 mounted(){
  console.log('mounted start');
 },
 methods:{
  judge(){// 将判断逻辑写入judge方法
  if(this.is_finish){
   this.modalMsg="活动已结束"
   return;
  }
  if(this.is_exchange){
   this.modalMsg="您已兑换奖品"
   return;
  }
  }
 }

至此,问题解决。有同学可能会问,在 vm 中调用 judge 方法时, mounted 已执行,此时页面已渲染,再去判断初始状态,会不会有闪烁问题?本人经过测试,发现不会,据此推断,在 mounted 执行结束之后,页面没有开始更新动作,而是在执行完 vm 回调之后,再去渲染。这样的话,逻辑上就行得通了,但是这个只是推断,还需要在源码层面找到依据才可以。

github地址

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

Javascript 相关文章推荐
JQuery 拾色器插件发布-jquery.icolor.js
Oct 20 Javascript
Jquery获得控件值的三种方法总结
Feb 13 Javascript
jquery禁用右键示例
Apr 28 Javascript
Javascript中数组sort和reverse用法分析
Dec 30 Javascript
文字垂直滚动之javascript代码
Jul 29 Javascript
AngularJS实现单独作用域内的数据操作
Sep 05 Javascript
Vue中建立全局引用或者全局命令的方法
Aug 21 Javascript
详解vue-router 路由元信息
Sep 13 Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
Jun 14 Javascript
vue升级之路之vue-router的使用教程
Aug 14 Javascript
基于JS实现前端压缩上传图片的实例代码
May 14 Javascript
Vue实现日历小插件
Jun 26 Javascript
微信小程序如何连接Java后台
Aug 08 #Javascript
vue 实现Web端的定位功能 获取经纬度
Aug 08 #Javascript
Vue-cli3.X使用px2 rem遇到的问题及解决方法
Aug 08 #Javascript
从零撸一个pc端vue的ui组件库( 计数器组件 )
Aug 08 #Javascript
非常实用的jQuery代码段集锦【检测浏览器、滚动、复制、淡入淡出等】
Aug 08 #jQuery
微信小程序嵌入腾讯视频源过程详解
Aug 08 #Javascript
17道题让你彻底理解JS中的类型转换
Aug 08 #Javascript
You might like
php 无限极分类
2008/03/27 PHP
php在多维数组中根据键名快速查询其父键以及父键值的代码
2011/05/07 PHP
php三维数组去重(示例代码)
2013/11/26 PHP
php除数取整示例
2014/04/24 PHP
推荐一款PHP+jQuery制作的列表分页的功能模块
2014/10/14 PHP
php文件上传类完整实例
2016/05/14 PHP
浅谈PHP链表数据结构(单链表)
2016/06/08 PHP
PHP filesize函数用法浅析
2019/02/15 PHP
Laravel5.0+框架邮件发送功能实现方法图文与实例详解
2019/04/23 PHP
jQuery 加上最后自己的验证
2009/11/04 Javascript
多个checkbox被选中时如何判断是否有自己想要的
2014/09/22 Javascript
javascript定义类和类的实现实例详解
2015/12/01 Javascript
Node.js的MongoDB驱动Mongoose基本使用教程
2016/03/01 Javascript
轻松理解JavaScript之AJAX
2017/03/15 Javascript
JavaScript实现三级联动菜单效果
2017/08/16 Javascript
详解angular笔记路由之angular-router
2017/09/12 Javascript
浅谈如何使用 webpack 优化资源
2017/10/20 Javascript
使用javascript做在线算法编程
2018/05/25 Javascript
微信小程序canvas绘制圆角base64图片的实现
2019/08/18 Javascript
浅谈Vue使用Cascader级联选择器数据回显中的坑
2020/10/31 Javascript
[01:24:34]2014 DOTA2华西杯精英邀请赛5 24 DK VS LGD
2014/05/25 DOTA
详解Python中的相对导入和绝对导入
2017/01/06 Python
Python计算斗牛游戏概率算法实例分析
2017/09/26 Python
pandas获取groupby分组里最大值所在的行方法
2018/04/20 Python
Python+selenium点击网页上指定坐标的实例
2019/07/05 Python
Python解析命令行读取参数之argparse模块
2019/07/26 Python
python Tensor和Array对比分析
2020/01/08 Python
Python log模块logging记录打印用法解析
2020/01/20 Python
使用Python通过oBIX协议访问Niagara数据的示例
2020/12/04 Python
莫斯科大型旅游休闲商品超市:Camping.ru
2020/09/16 全球购物
商务英语专业毕业生自荐信
2013/11/05 职场文书
机关作风建设自查报告
2014/10/22 职场文书
2014年酒店工作总结与计划
2014/11/17 职场文书
企业承诺书格式范文
2015/04/28 职场文书
2015年村党支部工作总结
2015/04/30 职场文书
2015年学校管理工作总结
2015/07/20 职场文书