Я просто сделал это. Я использовал flatMap.
Вот отредактированная форма моего рабочего кода:
Обновлен с комментариями и используя панель и 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; })
Эта плоская карта берет каждый бар и делает новый веб-запрос, используя fooId из панели.
.flatMap(function (bar) { return getDataForFoo(data, bar, apiKey); })
Приведенный выше пример накапливает бары и foo s в модели данных. Кажется, вы просите поток бара, который содержит foo. С учетом вышеизложенного будет выглядеть так:
var barswithfoo = listOfBars(apiKey)
.flatMap(bar => {
return getFoo(bar.fooId, apiKey)
.map(foo => {
bar.foo = foo;
return bar;
});
})
.subscribe();
Вы можете видеть, что это похоже на ответ, который вы опубликовали. flatMap - карта + слияние. он ожидает, что карта вернет Observable и сразу же присоединяется к каждому наблюдаемому, который возвращается.
вы можете объяснить, что здесь происходит? 'name',' names', 'dataForName',' dataForNames'. Я немного смущен. Что такое «точка входа» здесь? – Agzam
не могли бы вы рассказать мне, что такое 'share()' зачем зачем вам нужно? – Agzam
Несомненно. Имена - это набор объектов bar из вопроса, а каждое имя - объект foo. Точкой входа является getDataForNames, которая возвращает Observable, которая испускает данные var каждый раз, когда она изменяется (путем добавления имени или ошибки). Я использую это, чтобы обновить хранилище редукции, которое затем запускает компонент реакции для отображения набора имен. –