async

转自 https://blog.csdn.net/gaoxuaiguoyi/article/details/47659343

                版权声明:本文为博主原创文章,未经博主允许不得转载。                    https://blog.csdn.net/gaoxuaiguoyi/article/details/47659343                </div>
                      <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-cd6c485e8b.css">
                          <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-cd6c485e8b.css">
      <div class="htmledit_views" id="content_views">

首先安装 模块async


测试代码:

call.js

exports.fun1 = function (callback) {
	setTimeout(function(){
	console.log('方法1');
	callback('1');
	},1900);
}
exports.fun2 = function (callback) {
setTimeout(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params"></span>)</span>{
<span class="hljs-built_in">console</span>.log(<span class="hljs-string">'方法2'</span>);
callback(<span class="hljs-string">'2'</span>);
},<span class="hljs-number">1700</span>);

}
exports.fun3 = function (callback) {

setTimeout(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params"></span>)</span>{
<span class="hljs-built_in">console</span>.log(<span class="hljs-string">'方法3'</span>);
callback(<span class="hljs-string">'3'</span>);

},1500);
}
test.js:

var async = require('async');
var step = require('step');
var call = require('./call');

call.fun1(function(data){

<span class="hljs-built_in">console</span>.log(data);

});
call.fun2(function(data){

<span class="hljs-built_in">console</span>.log(data);

});
call.fun3(function(data){

<span class="hljs-built_in">console</span>.log(data);

});
console.log(‘正常执行的方法’);

没有使用异步之前,我们调用三个方法期望的结果是:输出:方法1,方法2,方法3,但是node本身异步的机制决定了它不能像其他同步语言一样正常输出,结果输出是以时间花费最少的先执行:结果



这就是node的异步机制,我们使用async同步模块进行再次测试

加入代码:

function seriesFunc() {
<span class="hljs-keyword">async</span>.series([


    <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">callback</span>) </span>{
       
        call.fun1(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">data</span>)</span>{
		
        		
        		callback(<span class="hljs-literal">null</span>,data);
        });
    },
    <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">callback</span>) </span>{
        
        call.fun2(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">data</span>)</span>{

        		
        		callback(<span class="hljs-literal">null</span>,data);
        });
    },
    <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">callback</span>) </span>{
        
        call.fun3(<span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">data</span>)</span>{
        		
        		callback(<span class="hljs-literal">null</span>,data);
        });
    }],
    <span class="hljs-function"><span class="hljs-keyword">function</span>(<span class="hljs-params">error,result</span>) </span>{
        <span class="hljs-keyword">if</span>(error) {
            <span class="hljs-built_in">console</span>.log(<span class="hljs-string">"error: "</span>,error,<span class="hljs-string">"msg: "</span>,result);
        }
        <span class="hljs-keyword">else</span> {
            <span class="hljs-built_in">console</span>.log(<span class="hljs-string">"方法执行完毕"</span>+result);
        }
    }
);

}
seriesFunc();运行结果是否是我们期望的一次执行呢?



结果果然是我们期待的一样,顺序进行执行,node异步的机制就决定了,响应速度快,做web开发的优势。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值