复杂Vue组件的异步流程分析

栏目: JavaScript · 发布时间: 5年前

内容简介:如果一个组件的状态,依赖于异步任务的执行,那么这个状态就是异步的,我们称之为异步状态。异步状态会引入不确定性,换句话说就是,代码执行结果的正确与否完全靠运气或者靠网速。更糟糕的是,这种不确定性会可能向外扩散向内渗透,进而影响到整个应用的稳定性。我们知道Vue关于数据视图双向绑定的实现是基于观察者模式,在这个过程中,我们Observe组件状态、创建Watcher、订阅事件变化,并在nextTick中flush我们的schedulerQueue。Vue的这种基于nextTick的处理机制,再加上我们自己的异步代

如果一个组件的状态,依赖于异步任务的执行,那么这个状态就是异步的,我们称之为异步状态。异步状态会引入不确定性,换句话说就是,代码执行结果的正确与否完全靠运气或者靠网速。更糟糕的是,这种不确定性会可能向外扩散向内渗透,进而影响到整个应用的稳定性。

NextTick让异步状态更加难以捉摸

我们知道Vue关于数据视图双向绑定的实现是基于观察者模式,在这个过程中,我们Observe组件状态、创建Watcher、订阅事件变化,并在nextTick中flush我们的schedulerQueue。

Vue的这种基于nextTick的处理机制,再加上我们自己的异步代码,两者结合起来共同影响的那些异步状态,会给我们的代码稳定性带来很大挑战。

如果我们处理不好这种异步状态,Vue的表现会变得让人难以捉摸。具体来说就是watch的handler执行时机、视图的更新时机等问题,因为他们都依赖于nextTick机制,而在nextTick这个时刻,我们自己的异步代码的执行状态又是不确定的,这就导致Vue在nextTick时可能面临的是一个不稳定的异步状态。因此,Vue不得不多次执行watch的handler,或者多次更新视图,以保证最新的状态都已经得到"应用"。

一个熟悉的问题

我们应该见过这样的面试题:

(function test() {
    setTimeout(function() {console.log(4)}, 0);
    new Promise(function executor(resolve) {
        console.log(1);
        for( var i=0 ; i<10000 ; i++ ) {
            i == 9999 && resolve();
        }
        console.log(2);
    }).then(function() {
        console.log(5);
    });
    console.log(3);
})()
--------------------- 
作者:Front_end_lh 
来源:CSDN 
原文:https://blog.csdn.net/qq_31628337/article/details/71056294 
版权声明:本文为博主原创文章,转载请附上博文链接!
复制代码

如果我们已经了解过js的事件循环机制,我们都能轻松地预测出代码的执行顺序,但是一旦跟Vue结合起来,事情就会麻烦很多。

点击查看一个刻意复杂化的例子以模拟真实项目中的复杂逻辑 ,预测一下运行顺序是怎样的?

能否准确预测代码的执行情况,不仅是确保程序稳定运行的重要前提,更是衡量我们对框架理解程度的重要指标。

我们该怎么做

实际开发中业务组件会不可避免的复杂化,甚至有些业务性很重的子组件还会发起异步请求,导致异步状态分布在多个组件当中,这个时候对Vue执行过程的分析就很困难了。

或许你会想,直接使用vue-router的这种方案,在路由进入前把所有异步数据都准备不就行了吗?这的确可以解决大部分问题,但是有一些特殊的业务需求,需要动态的根据一些"参数"去发起请求,所以还是摆脱不了这个问题。

为了应对各种各样的需求,我们在写任何存在异步任务的代码时,都要提前做好流程设计,要确保代码的运行是严格符合期望的。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

妙手回春

妙手回春

(美)Steve Krug / 袁国忠 / 人民邮电出版社 / 2010-7 / 39.00元

本书是作者Steve Krug继畅销书《点石成金:访客至上的网页设计秘笈》(Don't Make Me Think)后推出的又一力作。多年来,人们就认识到网站可用性测试可以极大地改善产品质量,但鉴于正规的可用性测试流程复杂、费用高昂,很少人这样做。在本书中,作者详细阐述了一种简化的网站可用性测试方法,让任何人都能够尽早并频繁地对其网站、应用程序和其他产品进行可用性测试,从而将最严重的可用性问题消灭......一起来看看 《妙手回春》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

SHA 加密
SHA 加密

SHA 加密工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具