3 回答

TA貢獻1836條經驗 獲得超3個贊
在node.js開發過程中會遇到層層回調,雖然回調是node.js的優勢所在,但同樣也是坑。有如下場景需要返回多層回調函數中的結果:
http.request("/url", function(res){
obj.get(res, function(res2){
obj.get(res2,function(res3){
//此處可以得到res3
});
});
console.log('結束');
});
假如有一個函數
var func1 = function() {
//在這里會用到上面的那段代碼
}
就像下面這樣
router.get('url', function(req, res) {
http.request("/url", function(res1) {
obj.get(res, function(res2) {
obj.get(res2,function(res3) {
//得到res3后傳值到頁面
res.render('html',{res:res3})
});
});
});
});
如果我們有多個路由都需要用到那段代碼的返回值,我們或許會把它提取出來當做一個公共的部分來使用,于是把它放到一個函數中:
var func2= function(){
http.request("/url", function(res){
obj.get(res, function(res2){
obj.get(res2,function(res3){
//在此處返回得到的值
returen res3;
});
});
console.log('結束');
});
}
然后在每個路由中調用,可是結果卻出人意料,在調用func2()以后并沒有得到想要的結果res3,事實上已經輸出了“結束”兩字。
其實這就是node.js的異步回調導致的結果,整個代碼段走完了,回調函數中的值卻沒有返回。
那該怎么辦?解決辦法還是用回調解決,將上面代碼改寫:
var func2= function(param, callback) {
http.request("/url", function(res) {
obj.get(res, function(res2) {
obj.get(res2,function(res3) {
callback(res3);
});
});
console.log('結束');
});
}
接下來就是調用上面這段代碼:
router.get("url", function(req, res) {
func2(p1, function(res2) {
res.render("html", {res:res2});
});
});

TA貢獻1827條經驗 獲得超4個贊
1.阻塞調用(讀取完文件再執行后面的操作)
var fs = require("fs");
var data = fs.readFileSync('/fs.txt');
console.log(data.toString());
console.log("程序執行結束!");
輸出結果:
“文件內容”
“程序執行結束!”
2.非阻塞調用(讀取文件和其他操作同步執行)
var fs = require("fs");
fs.readFile('/fs.txt',function(err,data){
if(err) return console.error(err);
console.log(data.toString());
});
console.log("程序執行結束!");
輸出結果:
“程序執行結束!”
“文件內容”
如果我們每行代碼的執行都不依賴于上一行代碼的執行結果,那沒問題,順序執行就好。但是如果我們某行代碼的執行,依賴于上一行代碼的結果,這個時候就需要回調函數了。我們必須要使用回調函數返回上一行代碼的結果,然后才能繼續執行這一行代碼。

TA貢獻1802條經驗 獲得超6個贊
簡單點說,用戶是實現方,實現方需要調用A()函數,但為了A()函數具有通用性,需要根據實現方的意愿調用實現方提供的函數cbB(),在這里cbB()即為回調函數。
在Windows編程中回調函數用途很廣泛。
完成的回調函數進行計數判斷:
function check () {
nums–;
if (nums === 0) { // do something. }
}
- 3 回答
- 0 關注
- 3276 瀏覽
添加回答
舉報