肯定有一种方法可以将响应返回给客户端。我们在Flashlight 搜索集成中有一个很好的例子:
function doSearch(index, type, query) {
var ref = new Firebase(URL+'/search');
var key = ref.child('request').push({ index: index, type: type, query: query }).key();
console.log('search', key, { index: index, type: type, query: query });
ref.child('response/'+key).on('value', showResults);
}
此代码在客户端 JavaScript 应用程序中运行,并在调用push()
. 然后它“等待”响应返回到函数的最后一行。这里的关键是它使用它用来发送请求的 sam push id/key 来监听响应。这样请求和响应就会匹配。
虽然 Firebase Queue 没有对这种“握手”的内置支持,但您可以轻松地将其自己构建到应用程序的客户端和服务器代码中。添加任务时,添加请求 ID(来自firebase-queue 示例的适配器):
var request_id = ref.push().key();
ref.child('queue/tasks').push({ requestId: request_id, foo: 'bar' });
在您的任务工作者中,您执行通常的处理,然后使用相同的请求 ID(来自firebase-queue 示例的适配器)将响应写回数据库:
var ref = new Firebase('https://<your-firebase>.firebaseio.com/queue');
var responses = new Firebase('https://<your-firebase>.firebaseio.com/responses');
var queue = new Queue(ref, function(data, progress, resolve, reject) {
// Read and process task data
console.log(data);
// Do some work
progress(50);
// Finish the task asynchronously
setTimeout(function() {
// write the response to the client
responses.child(data.requestId).set({ allDone: true });
// tell firebase-queue that we're done
resolve();
}, 1000);
});