WedX - журнал о программировании и компьютерных науках

Конвертировать Promise.all([список промисов]) в ramda

Я написал функцию, которая возвращает список промисов (код в ramda), а затем я должен окружить его с помощью Promise.all(), чтобы разрешить все промисы и отправить их обратно в цепочку промисов.

Например,

// Returns Promise.all that contains list of promises. For each endpoint we get the data from a promised fn getData().
const getInfos = curry((endpoints) => Promise.all(
  pipe(
    map(getData())
  )(endpoints))
);

getEndpoints()   //Get the list of endpoints, Returns Promise
  .then(getInfos) //Get Info from all the endpoints
  .then(resp => console.log(JSON.stringify(resp))) //This will contain a list of responses from each endpoint

promiseFn — это функция, которая возвращает обещание.

Как я могу лучше всего преобразовать эту функцию в полную версию Ramda и использовать либо pipeP, либо что-то еще? Может кто-нибудь порекомендовать?

25.04.2017

  • Можете ли вы объяснить более подробно, что это делает, возможно, с более явными именами переменных? Например, что делает внешний pipe? Это выглядит неактуально. Что делает promiseFn? 25.04.2017
  • @ScottSauyet Я обновил вопрос, пожалуйста, дайте мне знать, если вам нужна дополнительная информация. Спасибо 26.04.2017
  • Я понятия не имею, что вы имеете в виду под разрушает идею использования каррированных функций 26.04.2017
  • @Bergi Я хочу, чтобы getInfo() полностью использовал Ramda, например, при выполнении всех обещаний через ramda? 26.04.2017
  • Как один из руководителей Ramda, я должен предположить, что создание чего-либо полностью с использованием Ramda никогда не должно быть целью, если только это не упражнение для изучения Ramda. Это просто инструмент, который можно использовать там, где он помогает. 26.04.2017
  • @geek Итак, вы хотите избежать использования объявлений const, инициализаторов, стрелочных функций, параметров, использования Promise.all, вызовов функций, использования getData? Все они не являются частью Ramda. 26.04.2017
  • Что делает pipe(map(getData()))(endpoints) такого, чего не сделал бы map(getData(), endpoints)? 26.04.2017
  • Также является ли getData нулевой функцией, которая возвращает функцию, которая преобразует конечную точку во что-то? Странно иметь map(something(/* no args here*)). 26.04.2017
  • @ScottSauyet Спасибо за комментарии. Некоторые из них действительно помогли. Но я действительно хотел удалить Promise.all и по-прежнему иметь возможность разрешать список промисов, возвращаемых getData() и map. 27.04.2017
  • @Bergi Спасибо, но я действительно хочу удалить вызов Promise.all и попытаться использовать для этого все, что доступно в Ramda? 27.04.2017
  • @geek Нет, в Ramda нет эквивалента Promise.all именно потому, что он уже доступен как встроенный 27.04.2017
  • @Bergi: Это не совсем причина, по которой у Ramda нет эквивалента. На самом деле у нас есть эквиваленты чистых функций для многих нативных методов. Мы очень мало занимаемся промисами, потому что никто из авторов особо не любит промисы, предпочитая более законные типы, такие как фьючерсы или задачи. 28.04.2017
  • В своей трубе вы можете сделать R.invoker(1, 'all')(R.__, Promise) 15.10.2020

Ответы:


1

Не уверен, чего вы хотите достичь, но я бы переписал это так:

const getInfos = promise => promise.then(
  endpoints => Promise.all(
    map(getData(), endpoints)
  )
);

const log = promise => promise.then(forEach(
  resp => console.log(JSON.stringify(resp))
));

const doStuff = pipe(
  getEndpoints,
  getInfos,
  log
);

doStuff();
05.05.2017

2

Я думаю, вы имеете в виду использование бесточечной нотации.

Я рекомендую использовать compose. Это отличный инструмент при использовании ramda.

const getInfos = R.compose(
  Promise.all,
  R.map(getData),
);

// Now call it like this.
getInfos(endpoints)
  .then(() => console.log('Got info from all endpoints!'));

// Because `getInfos` returns a promise you can use it in your promise chain.
getEndpoints()
  .then(getInfos) // make all API calls
  .then(R.map(JSON.stringify)) // decode all responses
  .then(console.log) // log the resulting array
14.02.2019

3

Я бы попробовал что-то вроде этого:

const getEndpoints = () =>
  Promise.resolve(['1', '2', '3', '4', '5', '6', '7', '8'])
const getEndpointData = (endpoint) =>
  Promise.resolve({ type: 'data', endpoint })

const logEndpointData = pipe(
  getEndpoints,
  then(map(getEndpointData)),
  then(ps => Promise.all(ps)),
  then(console.log)
)

logEndpointDatas()

Я стесняюсь совмещать всего 2 функции с pipe/compose. Такие вещи, как then(map(callback)), хорошо читаются, как только вы к ним привыкнете. И я стараюсь не принимать обещания за параметры.

13.06.2019
Новые материалы

Как создать диаграмму градиентной кисти с помощью D3.js
Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


Для любых предложений по сайту: [email protected]