[英]Run a function multiple times with different arguments sequentially in Node Js
[英]use then() to make function run sequentially in node
我想在序列總線中運行循環函數,函數總是得到異步有沒有任何方法使它同步而不使用回調或任何外部庫
檔案1
var db = require('./promiseUnderStanding');
var fun = function () {
for (var i = 0; i < 10; i++) {
db.getFromDb(i, 0);
}
}
fun();
文件2
var mysql = require("mysql");
module.exports = {
getFromDb : function (num1,num2) {
var mysql = require('mysql');
var connection = mysql.createConnection({
host: 'localhost',
user: 'root',
password: 'root',
database: 'demo'
});
connection.connect();
connection.query('SELECT '+num1+' + '+num2 +' AS solution', function (error, results, fields) {
if (error) {
console.log(err)
}
else {
console.log('The solution is: ', results[0].solution);
}
})
connection.end();
}
}
如果函數是異步的,這意味着它返回一個Promise。
const myFunc = function(){
return new Promise(function(resolve, reject){
if(failed){
reject(dataSendToCatch);
}if(!failed){
resolve(dataSendToThen);
}
})
};
這與以下幾乎相同:
const myFunc = async function(){
if(failed) throw new Error();
return dataSendToThen;
};
運行您的功能后,您可以鏈接異步甚至同步功能:
myFunc()
.then(function(dataFromResolve){return otherFunc()})
.then(function(dataFromOtherFunc){/*...*/});
無法同步運行異步承諾。
但是你要找的是Promise.all()
。 另外connection.open
也是異步的,並且快速打開和關閉mysql的連接效率不高。 您應該在循環之前打開連接,執行查詢然后關閉它(在我的示例中未顯示)。
例
檔案1:
var db = require('./promiseUnderStanding');
var fun = function () {
var promises = [];
for (var i = 0; i < 10; i++) {
promises.push[db.getFromDb(i, 0)];
}
Promise.all(promises).then(function(values){
console.log(values):
})
}
fun();
文件2:
var mysql = require("mysql");
module.exports = {
getFromDb : function (num1,num2) {
var mysql = require('mysql');
var connection = mysql.createConnection({
host: 'localhost',
user: 'root',
password: 'root',
database: 'demo'
});
var queryPromise = new Promise(function(resolve, reject) {
connection.connect(function(err){
connection.query('SELECT '+num1+' + '+num2 +' AS solution', function (error, results, fields) {
if (error) {
reject(error)
}
else {
resolve(results)
}
});
})})
connection.end();
return queryPromise;
}
}
你的問題似乎是關於異步函數,所以我認為數據庫邏輯超出了范圍。
使用async-await :
檔案1:
const fun = async function () {
for (var i = 0; i < 10; i++) {
await db.getFromDb(i, 0);
}
}
fun().then(onFinish).catch(onError);
文件2:
module.exports.getFromDb = function() {
return new Promise((resolve, reject) => {
// If success
resolve(result);
// If fail
reject(error);
});
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.