@Kipsi

В чем будет отличия map от forEach при сортировке?

Здравствуйте. Подскажите пожалуйста как поменяется функционал сортировки если forEach заменить на map?
const sortRev = document.querySelector('.sortRev');
const result = document.querySelector('.result');

function sortByFeed(arrs) {
 const arrCopy = JSON.parse(JSON.stringify(arrs));
 arrCopy.forEach((item) => {return item.ratingRevievs = +item.ratingRevievs.replace(/\D/g, '')}) 
 arrCopy.sort((a,b) => {return a.ratingRevievs > b.ratingRevievs ? 1 : -1})
  result.innerHTML = ''
  arrCopy.forEach((items) => {
   result.innerHTML += `
    <h3>${items.name}</h3>
    <p>${items.ratingRevievs}</p>
   `
 }) 
}

sortRev.addEventListener('click' , () => {
  sortByFeed(items)
})

arrCopy.map((item) => {...}) 
 arrCopy.map((items) => {...})
  • Вопрос задан
  • 102 просмотра
Пригласить эксперта
Ответы на вопрос 3
Seasle
@Seasle Куратор тега JavaScript
Помог - отметь решением \( ゚ヮ゚)/
forEach перебирает текущую коллекцию, map перебирает текущую и возвращает новую.
Ответ написан
john36allTa
@john36allTa
That`s calling Walker
Не по теме,но так лучше и наглядно и по количеству вычислений
function sortByFeed(arrs) {
 const arrCopy = JSON.parse(JSON.stringify(arrs));
 const h = item => +item.ratingRevievs.replace(/\D/g, '')
 arrCopy.sort((a,b) => h(a) - h(b))
  result.innerHTML = ''
  arrCopy.forEach((items) => {
   result.innerHTML += `
    <h3>${items.name}</h3>
    <p>${items.ratingRevievs}</p>
   `
 }) 
}
Ответ написан
@Che603000
c 2011 javascript
const arrCopy = JSON.parse(JSON.stringify(arrs))
 .map(item => {
   item.ratingRevievs = +item.ratingRevievs.replace(/\D/g, ''); 
   return item;
 })
 .sort((a,b) => a.ratingRevievs > b.ratingRevievs ? 1 : -1)
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы