javascript - 根据 Observable 元素的属性解析 Observables

标签 javascript reactive-programming rxjs

如果我有从 api 进入 Observable 的项目列表,我们称它们为“bars”列表

现在,对于每个 bar,我都需要获取相关项目的列表 - 让我们称它们为“foo”。事情是这样的——仅当提供了相关联的 bar 的 id 时,api 才允许您检索 foo 的列表。

那我该怎么做呢?我应该在 subscribe | 中触发一个单独的请求吗?对于每个?或者我可以创建 url 流并以某种方式将它们与 bars 流合并,然后那样做?

当应用于 UI 内容时,您可以使用 Rx 创造奇迹,不幸的是,我很难使用它来处理多个 ajax 请求。

当你有一个 Observable 并为每个项目检索更多数据时,你能给我举个例子吗?

例如,如果我尝试做这样的事情:

Rx.Observable.fromArray([ { bar:1 }, { bar:2 }, { bar:3 } ])
.map((x)=> {
    x.foo = Rx.Observable.fromPromise(grabFoo(x));

    return x;
}).subscribe((x)=> console.log(x))

那是行不通的。那么我该怎么做呢?

最佳答案

我刚刚做到了。我用的是 flatMap。

这是我的工作代码的编辑形式:

更新了注释并使用 Bar 和 Foo 并添加了 listofbars()

// accumulates all bar s and foo s
var data = {bars: [], errors: []};

// return observable of a foo
var getFoo = function (Id, apiKey) {
    return Rx.Observable.fromPromise($.ajax({
        method: "GET",
        url: config.Uri + "/foos/" + Id,
        headers: { "Authorization": "Bearer " + apiKey },
    })).share();
};
// return Observable of an array of bars
var getBars = function (apiKey) {
    return Rx.Observable.fromPromise($.ajax({
        method: "GET",
        url: config.Uri + "/bars",
        headers: { "Authorization": "Bearer " + apiKey },
    })).share();
};
// flatten Observable of an array of bar s to Observable of bar s
var listOfBars = function (apiKey) {
    return getBars(apiKey)
    .flatMap(function (ep) { return (_a = Rx.Observable).of.apply(_a, ep); var _a; });
}
// accumulate foos into data
var getDataForFoo = function (data, bar, apiKey) {
    return getFoo(bar.fooId, apiKey)
    .map(function (foo) {
        bar.foo = foo;
        data.bars.push(bar);
        return data;
    })
    .catch(function (ex) {
        data.errors.push({ name: { Id: Id, name: Name }, error: ex });
        return Rx.Observable.of(data);
    });
};
var getDataForBars = function (data, apiKey) {
    return listOfBars(apiKey)
    .flatMap(function (bar) { return getDataForFoo(data, bar, apiKey); })
    .catch(function (ex) {
        data.errors.push({ names: { Id: Id }, error: ex });
        return Rx.Observable.of(data);
    });
};

这个 flatMap 接受条形数组并分别发出每个条形。

    .flatMap(function (ep) { return (_a = Rx.Observable).of.apply(_a, ep); var _a; })

这个 flatMap 获取每个条并使用条中的 fooId 发出新的 Web 请求。

    .flatMap(function (bar) { return getDataForFoo(data, bar, apiKey); })

上面的示例将 bar 和 foo 累积到一个数据模型中。您似乎在要求包含 foo 的 bar 流。鉴于以上内容,它看起来像:

var barswithfoo = listOfBars(apiKey)
    .flatMap(bar => { 
        return getFoo(bar.fooId, apiKey)
            .map(foo => {
                bar.foo = foo; 
                return bar;
            });
    })
    .subscribe();

您可以看到这与您发布的答案相似。 flatMap 是映射+合并。它期望 map 返回一个 Observable 并立即订阅返回的每个 observable。

关于javascript - 根据 Observable 元素的属性解析 Observables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33114650/

相关文章:

javascript - 我能知道图像在特定位置是否透明吗?

ios - Rx scan(),无法从种子和另一个可观察对象生成可观察对象

angular - .maps 和导入 'rxjs/add/operator/map' 出现问题;

angular - 如何通过 RxJs 链传递值

javascript - 如何为按钮文本设置动画? (加载类型的动画)-jquery?

javascript - 正则表达式不重复点字符javascript

spring - @enabler2dbcrepositories 无法找到我的存储库

objective-c - 在 dispatch_queue sendComplete 上创建的 RACSubject 没有进入合并信号

javascript - 事件组合

javascript - 为所有数组元素调用函数,而不将 item 作为参数传递