Należy unikać piramidy zagłady:
var express = require('express');
var Q = require('Q');
var app = express();
app.get('/',function(req,res){
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : ''
});
connection.connect();
function doQuery1(){
var defered = Q.defer();
connection.query('SELECT 1 AS solution',defered.makeNodeResolver());
return defered.promise;
}
function doQuery2(){
var defered = Q.defer();
connection.query('SELECT 2 AS solution',defered.makeNodeResolver());
return defered.promise;
}
Q.all([doQuery1(),doQuery2()]).then(function(results){
res.send(JSON.stringify(results[0][0][0].solution+results[1][0][0].solution));
// Hint : your third query would go here
});
connection.end();
});
app.listen(80);
console.log('Listening on port 80');
Ten przykład pokazuje wynik, który zależy od 2 niezależnych obliczonych wartości. Każda z tych wartości jest odpytywana w doQuery1 i doQuery2. Są wykonywane po kolei, ale asynchronicznie.
Następnie możesz zobaczyć Q.all(...
które w zasadzie nazywają wywołanie zwrotne „wtedy” w przypadku sukcesu. W ramach tej funkcji zwrotnej obliczenia są wykonywane.
Korzystanie z obietnic (szczegóły:Github Q:obietnica dla Javascript i wikipedia ) pozwalają na czystszy kod, oddzielne obliczenia i obsługę wyników oraz poruszanie się.
Zobacz, jak łatwo byłoby dodać „doQuery3” jako warunek wstępny obliczeń!
A poniżej "package.json" należący do przykładowego kodu:
{
"name": "hello-world",
"description": "hello world test app",
"version": "0.0.1",
"private": true,
"dependencies": {
"express": "3.2.0",
"q": "0.9.3",
"mysql":"2.0.0-alpha7"
}
}