Привязка методов JS Set приводит к ошибке TypeError

Почему

screens.reduce((acc,s) =>
    acc.add(s._created_by).add(s._last_modified_by), new Set());

работают, как ожидалось (в набор добавляются две вещи на каждой итерации), тогда как добавление .delete("admin"), как в

screens.reduce((acc,s) =>
    acc.add(s._created_by).add(s._last_modified_by).delete("admin"), new Set());

приводит к TypeError: acc.add is not a function

Поведение ключевого слова "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
0
22
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

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

Проверьте документы для Set.prototype.delete:

Return value

true if an element in the Set object has been removed successfully; otherwise false

Он не возвращает Set. Итак, если вы хотите использовать reduce и delete таким образом, вам придется использовать два разных оператора, а не только один связанный:

screens.reduce((acc,s) => {
  acc
    .add(s._created_by)
    .add(s._last_modified_by)
    .delete("admin");
  return acc;
} , new Set());

(Я полагаю, вы также можете использовать оператор запятой, чтобы избежать использования блоков { / }, но только ради игры в гольф это повредит ясности кода)

OMG - JS все еще есть способ вести себя как функциональный язык - спасибо !!!!

Simon H 22.11.2018 09:21

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