Родительский компонент возвращает дочерние div один за другим

Компоненты A и B возвращают массив элементов div (которые обновляются в зависимости от глобальных изменений состояния) следующим образом:

// code above

return(
  <>{divArray}</>
)

Компонент C импортирует оба компонента и возвращает их в div:

// code above
return(
  <div className='CC'>
    <A/>
    <B/>
  </div>
)

В обычном рендере массив компонента A будет отображаться над массивом компонента B. Можно ли заставить div 'CC' показывать элементы обоих массивов один за другим, то есть элемент массива A, элемент массива B, элемент массива A и т. д.?

Могу ли я как-то вызвать .map для импортированных компонентов в операторе возврата C?

Отвечает ли это на ваш вопрос? Доступ к дочерним элементам реагирующего элемента

Peter B 24.07.2023 23:48

Ну, вы можете сделать это одним из двух способов. Если количество индексов одинаковое.. Вы можете просто map() первый массив и использовать key для вызова этого index во втором массиве внутри цикла. Или вы можете useEffect передать оба массива и создать один компонент со всеми divs таким образом.

Zak 24.07.2023 23:48

@PeterB это слишком сложно, должно быть что-то проще...

E.Z 25.07.2023 00:20

Я бы сказал, что нет более простого способа. React не создан для таких трюков. Компоненты предназначены для рендеринга в компоненты меньшего/нижнего уровня, которые могут или не могут рендерить другой слой дочерних элементов по тому же принципу. И обычно вам не нужно видеть это снаружи. Что бы я сделал, если бы у меня была такая необходимость, так это демонтировать A и B и вместо этого создать функции, которые просто перенастраивают нужные вам массивы. Нет необходимости, чтобы все было компонентом JSX.

Peter B 25.07.2023 00:40

да, это то, что у меня есть сейчас, я думал, что могу сделать его более сложным, но не могу найти ... Просто буду использовать useEffects и обрабатывать эти массивы внутри одного компонента, это намного проще ... Спасибо @PeterB!

E.Z 25.07.2023 00:45
Поведение ключевого слова "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) для оценки ваших знаний,...
2
5
51
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий
const C = () => {
  const arrayA = <A/>.type().props.children
  const arrayB = <B/>.type().props.children
   
  return (
    <div className='CC'>
      {
        getAlternatingArray(arrayA, arrayB)
      }
    </div>  
  )
}

const getAlternatingArray = (arrayA, arrayB) => {
    let indexA = 0
    let indexB = 0
    const result = []
    while(indexA < arrayA.length && indexB < arrayB.length) {
      result.push(arrayA[indexA++]);
      result.push(arrayB[indexB++]);
    }
    while(indexA < arrayA.length) {
      result.push(arrayA[indexA++]);
    }
    while(indexB < arrayB.length) {
      result.push(arrayB[indexB++]);
    }
  return result
}

если это сработает, вы гений, скоро проверим.

E.Z 25.07.2023 19:32

Это работает, вот вам codepen В любом случае я не гений, ха-ха

Nicolas 25.07.2023 19:38

Мне интересно, почему вы используете .map(), потому что он работает даже без .map(), а без него такие вещи, как style и className, которые могут быть на <div>-ах, сохраняются. С .map() как есть (выполнение createElement), эти реквизиты теряются, необходимо добавить дополнительный код, чтобы вернуть все это обратно.

Peter B 25.07.2023 23:28

Вы правы, @peter, отредактировал ответ, не нужно их сопоставлять.

Nicolas 26.07.2023 16:02

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