首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ReactPHP和Promises

ReactPHP和Promises
EN

Stack Overflow用户
提问于 2017-02-09 02:57:26
回答 1查看 533关注 0票数 1

我正在尝试使用ReactPHP来理解Promise的概念

代码语言:javascript
复制
$app = function ($request, $response) use ($redis, $config) {

    $promise = React\Promise\all(
        array(
            AsyncGetUser(),
            AsyncGetDB(),
            AsyncGetTemplate()
        )
    )->then(function ($res) {
        $result = ParseTemplate($user, $template, $whatever);
    }

    \React\Promise\resolve($promise);


    $response->writeHead(200, array('Content-Type' => 'text/plain'));
    $response->end($result);

}

$http->on('request', $app);

但是在$result准备好之前就发送了$response。怎样才能正确地发送$result等待$promise

我尝试将函数移到another->then()部分,但在浏览器中没有得到任何响应(即,当$app = $response->end已经完成时,脚本会得到结果)。

EN

回答 1

Stack Overflow用户

发布于 2017-02-09 11:05:17

我根本不知道reactphp,但是如果promises像JS中的promises一样工作,看起来你需要在->then中编写响应,在那里你会得到一个结果!

代码语言:javascript
复制
$app = function ($request, $response) use ($redis, $config) {
    $promise = React\Promise\all(
        array(
            AsyncGetUser(),
            AsyncGetDB(),
            AsyncGetTemplate()
        )
    )->then(function ($res) {
        $result = ParseTemplate($user, $template, $whatever);
        $response->writeHead(200, array('Content-Type' => 'text/plain'));
        $response->end($result);
    }
}

$http->on('request', $app);

注意:代码中的以下行

代码语言:javascript
复制
\React\Promise\resolve($promise);

这没有任何意义。\React\Promise\resolve并不像您想象的那样“解析承诺”,它创建并返回一个解析的承诺--您可以丢弃它!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42121428

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档