Вставлять элементы в массив с помощью else

В моем машинописном коде у меня есть массив продуктов

products = [10,25,45,89];

Я звоню в службу поддержки, чтобы найти клиента, который совершил покупку продукта.

products.forEach(x => 
  this.clientService.getclientOrdersByProduct(clientId, x)
  .subscibe(s=>{ 
     if (s){ 
       this.clientOrders.push(s);
     } else{ 
       // add the product id
     }
   })
); 

проблема в том, что я хочу добавить еще и отправить идентификатор продукта в clientOrders. ClientOrders класс выглядит так

export interface ClientAccount{  product?: Product; ....}

как я могу добиться этого в другом?

Спасибо

Понятия не имею, о чем вы спрашиваете. Что вы имеете в виду, говоря «добавить еще»?

Mathias Lykkegaard Lorenzen 09.11.2018 14:13

Пожалуйста, включите больше информации в свой вопрос, непонятно, о чем вы спрашиваете.

laptou 09.11.2018 14:13

Я добавил комментарий о том, где должен быть другой.

Jack M 09.11.2018 14:14

ты про (s){ foo; } else { push into clientOrders }?

Jacopo Sciampi 09.11.2018 14:15

правильно @JacopoSciampi

Jack M 09.11.2018 14:16

объявить массив -> clientOrder: ClientAccount[] = [];, а затем в else -> this.clientOrder.push({product: something, productId: x);

Jacopo Sciampi 09.11.2018 14:19

Не могли бы вы опубликовать образец вывода?

Nikhil Aggarwal 09.11.2018 14:20

@NikhilAggarwal: какой образец?

Jack M 09.11.2018 14:22

@JackM - С заданным вводом, как будет выглядеть вывод, скажем, только 2 продукта имеют заказы, а остальные нет

Nikhil Aggarwal 09.11.2018 14:23

@JacopoSciampi, спасибо, что он работает, если вы добавите его в решение, я отмечу как ответ

Jack M 09.11.2018 14:36
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
10
66
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Предполагая, что интерфейс выглядит примерно так:

export interface ClientAccount{  
  product?: Product;
  productId: number;
  ...
}

ты можешь сделать это:

создать массив clientOrder:

clientOrder: ClientAccount[] = [];

в for

products.forEach(x => 
  this.clientService.getclientOrdersByProduct(clientId, x)
  .subscibe(s=>{ 
     if (s){ 
       this.clientOrders.push(s);
     } else{ 
       this.clientOrder.push({product: **something**, productId: x);
     }
   })
); 

something выделен жирным шрифтом, потому что я понятия не имею, какие данные вы получаете по этой подписке.

Другие вопросы по теме