Angular Rxjs останавливает все предыдущие запросы по событию клика и делает новый вызов

Я новичок в angular и застрял в сценарии, когда при загрузке страницы мне нужно запустить 4 разных API-интерфейса на ngOnit и иметь событие щелчка на той же странице при нажатии на событие, которое я хочу, чтобы оно остановило все предыдущие вызовы и делает новый вызов API.

Код.

ngOnInit(): void {
    this.getData('');
  }

getData(data) {
    const amount$ = this.service.getAmount(data).pipe(takeUntil(this.unSubscribe$));
    const rate$ = this.service.getRate(data).pipe(takeUntil(this.unSubscribe$));
    const applications$ = this.service.getApp(data).pipe(takeUntil(this.unSubscribe$));
    const statistics$ = this.service.getStat(data).pipe(takeUntil(this.unSubscribe$));
    applications$.subscribe(res => {
      if (res.success) {
        let d = res.dataSet;
        }
    }, (err) => {
    })
    ------ and another three subscribe here
  }

HTML

<button type = "button" (click) = "getData('abc')"
            >Event</button>

«abc» — это динамическая строка, которая изменяется в соответствии с необходимостью, а затем нажимаем кнопку, мы передаем уникальную строку в функцию getData, и на основе этой строки мы получаем новый вызов API при каждом нажатии на кнопку, но я хотите, чтобы при каждом щелчке он останавливал все предыдущие вызовы API и нажимал новый.

вы отписываетесь от наблюдателя?

Abru007 20.01.2023 11:47

Да в onDestroy

Ricky 20.01.2023 11:57
Поведение ключевого слова "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) для оценки ваших знаний,...
0
2
67
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Это типичный сценарий для оператора switchMap.

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

// define a BehaviorSubject, i.e. a subject that emits a first vale as soon as 
// it is subscribed. In this case it emits an empty string, as in the ngOnInit
start$ = new BehaviorSubject<string>('')

// then define the Observable that runs the APIs with start$ as its starting point
execute$ = start$.pipe(
  // here you place switchMap which means: as soon as I get a value from 
  // upstream, I unsubscribe and preceding subscription and start a new subscription
  switchMap(val => {
     // with merge here I run all the 3 APIs concurrently
     return merge(
      this.amount$(val), 
      this.rate$(val),
      this.applications$(val), 
      this.statistics(val)$
     )
  })
)

Каждый Observable, который запускает API, должен быть возвращен функцией, которая принимает строку в качестве входных данных, чтобы мы могли использовать значение, переданное нажатием кнопки, например:

сумма$ = (данные) => { вернуть this.service.getAmount(данные); };

Если это http-вызов, вам не нужны takeUntil и логика отписки, так как http-клиент, который предоставляет Angular, либо выдает один раз, а затем сразу завершается, либо выдает ошибки, поэтому отписка не нужна.

Теперь в ngOnInit вы создаете одну и только одну подписку, вот так

ngOnInit(): void {
    this.execute$.subscribe(// whatever is necessary)
}

и в обработчике события нажатия кнопки вы nextstart$ Тема, то есть вы заставляете start$ испускать строку, которую вы хотите

<button type = "button" (click) = "start$.next('abc')"
            >Event</button>

Вы можете найти пример (с имитацией http-вызовов) здесь.

Спасибо @Picci за ответ ... Для этого я могу получить все ответы API одновременно, но я хочу получить данные, если какой-либо API отправит ответ.

Ricky 20.01.2023 12:59

Что вы имеете в виду, говоря, что я хочу получать данные, если какой-либо API отправляет ответ? Каково желаемое поведение?

Picci 20.01.2023 15:47

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