详解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 相关文章推荐
JavaScript效率调优经验
Jun 04 Javascript
jquery实现简单的拖拽效果实例兼容所有主流浏览器(优化篇)
Jun 28 Javascript
javascript算法题:求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Apr 01 Javascript
利用Vue.js指令实现全选功能
Sep 08 Javascript
关于验证码在IE中不刷新的快速解决方法
Sep 23 Javascript
easyui-datagrid开发实践(总结)
Aug 02 Javascript
VUE长按事件需求详解
Oct 18 Javascript
在Express中提供静态文件的实现方法
Oct 17 Javascript
微信小程序select下拉框实现源码
Nov 08 Javascript
js实现盒子拖拽动画效果
Aug 09 Javascript
小程序实现可拖动的悬浮按钮
Sep 07 Javascript
详解Vue的异步更新实现原理
Dec 22 Vue.js
微信小程序如何连接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+AJAX实现无刷新注册(带用户名实时检测)
2007/01/02 PHP
用windows下编译过的eAccelerator for PHP 5.1.6实现php加速的使用方法
2007/09/30 PHP
用来解析.htgroup文件的PHP类
2012/09/05 PHP
php递归函数中使用return的注意事项
2014/01/17 PHP
php读取flash文件高宽帧数背景颜色的方法
2015/01/06 PHP
PHP4和PHP5版本下解析XML文档的操作方法实例分析
2017/05/20 PHP
PHP 网站修改默认访问文件的nginx配置
2017/05/27 PHP
php生成复杂验证码(倾斜,正弦干扰线,黏贴,旋转)
2018/03/12 PHP
分享精心挑选的12款优秀jQuery Ajax分页插件和教程
2012/08/09 Javascript
Extjs4中tree的拖拽功能(可以两棵树之间拖拽) 简单实例
2013/12/08 Javascript
从零学JSON之JSON数据结构
2014/05/19 Javascript
jquery通过ajax加载一段文本内容的方法
2015/01/15 Javascript
jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码分享
2015/04/22 Javascript
jQuery支持添加事件的日历特效代码分享(3种样式)
2015/08/24 Javascript
JS遍历DOM文档树的方法实例详解
2018/04/03 Javascript
Vue进度条progressbar组件功能
2018/04/17 Javascript
详解Nodejs内存治理
2018/05/13 NodeJs
vue this.reload 方法 配置
2018/09/12 Javascript
jQuery 动态粒子效果示例代码
2020/07/07 jQuery
python 正则式 概述及常用字符
2009/05/07 Python
python文件操作整理汇总
2014/10/21 Python
python实现百万答题自动百度搜索答案
2018/01/16 Python
python模块和包的应用BASE_PATH使用解析
2019/12/14 Python
Python3 pyecharts生成Html文件柱状图及折线图代码实例
2020/09/29 Python
CSS3实现淘宝留白的方法
2020/06/05 HTML / CSS
HTML5+CSS3应用详解
2014/02/24 HTML / CSS
加大码胸罩、内裤和服装:Just My Size
2019/03/21 全球购物
共产党员公开承诺书范文
2014/03/28 职场文书
个人主要事迹材料
2014/08/26 职场文书
乡镇三严三实学习心得体会
2014/10/13 职场文书
2014年办公室工作总结范文
2014/11/12 职场文书
2014收银员工作总结范文
2014/12/16 职场文书
亮剑观后感600字
2015/06/05 职场文书
遗失证明范文
2015/06/19 职场文书
基于JavaScript实现年月日三级联动
2021/06/22 Javascript
Java 定时任务技术趋势简介
2022/05/04 Java/Android