html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

node.js中使用q.js实现api的promise化_node.js_

[ ] 已经帮助:人解决问题

关于啥是promise以及promise解决的是啥问题,敬请体验node的回调异步编码大法,顺带移步http://wiki.commonjs.org/wiki/Promises/A 看看是咋定义的,在此不再赘述。Nz2HTML5中文学习网 - HTML5先行者学习网

这里我们看看怎么用q.js 实现node api的promise。Nz2HTML5中文学习网 - HTML5先行者学习网

一、万事开始皆为installNz2HTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
Nz2HTML5中文学习网 - HTML5先行者学习网
npm install qNz2HTML5中文学习网 - HTML5先行者学习网
Nz2HTML5中文学习网 - HTML5先行者学习网

二、标准node style api 的promise化方法Nz2HTML5中文学习网 - HTML5先行者学习网

1、使用Q.nfcallNz2HTML5中文学习网 - HTML5先行者学习网

相对于Q.fcall ,Q.nfcall 就是node 的Q.fcall。Nz2HTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
Nz2HTML5中文学习网 - HTML5先行者学习网
var FS = require('fs'),Nz2HTML5中文学习网 - HTML5先行者学习网
    Q   = require('q'),Nz2HTML5中文学习网 - HTML5先行者学习网
    colors = require('colors'),Nz2HTML5中文学习网 - HTML5先行者学习网
    file = 'example.txt';Nz2HTML5中文学习网 - HTML5先行者学习网
var fsReadFile = Q.nfcall(FS.readFile,file,encoding);Nz2HTML5中文学习网 - HTML5先行者学习网
fsReadFile.then(function(result){Nz2HTML5中文学习网 - HTML5先行者学习网
console.log((“invoke in nfcall ” + file).red);Nz2HTML5中文学习网 - HTML5先行者学习网
console.log(result.green);Nz2HTML5中文学习网 - HTML5先行者学习网
},function(error){Nz2HTML5中文学习网 - HTML5先行者学习网
console.log(“invoke in nfcall”.red);Nz2HTML5中文学习网 - HTML5先行者学习网
console.log(error.toString().red);Nz2HTML5中文学习网 - HTML5先行者学习网
}Nz2HTML5中文学习网 - HTML5先行者学习网
);Nz2HTML5中文学习网 - HTML5先行者学习网
Nz2HTML5中文学习网 - HTML5先行者学习网

2、使用Q.denodeifyNz2HTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
Nz2HTML5中文学习网 - HTML5先行者学习网
var fsReadFile_denodeify = Q.denodeify(FS.readFile);Nz2HTML5中文学习网 - HTML5先行者学习网
 Nz2HTML5中文学习网 - HTML5先行者学习网
fsReadFile_denodeify(file,encoding).then(function(result){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log("invoke in denodeify".red);Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(result.green)Nz2HTML5中文学习网 - HTML5先行者学习网
},function(error){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log("invoke in denodeify".red);Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(error.toString().red);Nz2HTML5中文学习网 - HTML5先行者学习网
}Nz2HTML5中文学习网 - HTML5先行者学习网
);Nz2HTML5中文学习网 - HTML5先行者学习网
Nz2HTML5中文学习网 - HTML5先行者学习网

3、使用Q.deferdNz2HTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
Nz2HTML5中文学习网 - HTML5先行者学习网
var fsReadFile_deferd = function(file,encoding){Nz2HTML5中文学习网 - HTML5先行者学习网
    var deferred = Q.defer();Nz2HTML5中文学习网 - HTML5先行者学习网
    FS.readFile(file,encoding,function(error,result){Nz2HTML5中文学习网 - HTML5先行者学习网
    if(error){Nz2HTML5中文学习网 - HTML5先行者学习网
        deferred.reject(error.toString().red);Nz2HTML5中文学习网 - HTML5先行者学习网
    }Nz2HTML5中文学习网 - HTML5先行者学习网
    deferred.resolve(result);Nz2HTML5中文学习网 - HTML5先行者学习网
});Nz2HTML5中文学习网 - HTML5先行者学习网
 Nz2HTML5中文学习网 - HTML5先行者学习网
return deferred.promise;Nz2HTML5中文学习网 - HTML5先行者学习网
};Nz2HTML5中文学习网 - HTML5先行者学习网
 Nz2HTML5中文学习网 - HTML5先行者学习网
fsReadFile_deferd(file).then(function(result){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log("invoke in deferd".red);Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(result.toString().green);Nz2HTML5中文学习网 - HTML5先行者学习网
},function(error){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log("invoke in deferd".red);Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(error.toString().red);Nz2HTML5中文学习网 - HTML5先行者学习网
}Nz2HTML5中文学习网 - HTML5先行者学习网
);Nz2HTML5中文学习网 - HTML5先行者学习网
Nz2HTML5中文学习网 - HTML5先行者学习网

4、使用makeNodeResolver()Nz2HTML5中文学习网 - HTML5先行者学习网

复制代码 代码如下:
Nz2HTML5中文学习网 - HTML5先行者学习网
var fsReadFile_makeNodeResolver = function(file,encoding){Nz2HTML5中文学习网 - HTML5先行者学习网
    var deferred = Q.defer();Nz2HTML5中文学习网 - HTML5先行者学习网
    FS.readFile(file,encoding,deferred.makeNodeResolver());Nz2HTML5中文学习网 - HTML5先行者学习网
    return deferred.promise;Nz2HTML5中文学习网 - HTML5先行者学习网
};Nz2HTML5中文学习网 - HTML5先行者学习网
 Nz2HTML5中文学习网 - HTML5先行者学习网
fsReadFile_makeNodeResolver(file,encoding).then(function(result){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log("invoke in makeNodeResolver".red);Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(result.green);Nz2HTML5中文学习网 - HTML5先行者学习网
},function(error){Nz2HTML5中文学习网 - HTML5先行者学习网
    console.log(error.toString().red);Nz2HTML5中文学习网 - HTML5先行者学习网
});Nz2HTML5中文学习网 - HTML5先行者学习网
Nz2HTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助