Сегодня я начал изучать ReactJS и через час столкнулся с проблемой ... Я хочу вставить компонент, который имеет две строки внутри div на странице. Упрощенный пример того, что я делаю ниже.
У меня есть html:
<html>
..
<div id="component-placeholder"></div>
..
</html>
Функция рендеринга выглядит так:
...
render: function() {
return(
<div className="DeadSimpleComponent">
<div className="DeadSimpleComponent__time">10:23:12</div >
<div className="DeadSimpleComponent__date">MONDAY, 2 MARCH 2015</div>
</div>
)
}
....
А ниже я вызываю рендер:
ReactDOM.render(<DeadSimpleComponent/>, document.getElementById('component-placeholder'));
Сгенерированный HTML выглядит так:
<html>
..
<div id="component-placeholder">
<div class="DeadSimpleComponent">
<div class="DeadSimpleComponent__time">10:23:12</div>
<div class="DeadSimpleComponent__date">MONDAY, 2 MARCH 2015</div>
</div>
</div>
..
</html>
Проблема в том, что я не очень доволен тем, что React заставляет меня обернуть все в div "DeadSimpleComponent". Какое решение является лучшим и простым без явных манипуляций с DOM?
ОБНОВЛЕНИЕ 28.07.2017: Сопровождающие React добавили эту возможность в React 16 Beta 1
Начиная с React 16.2 , вы можете сделать это:
render() {
return (
<>
<ChildA />
<ChildB />
<ChildC />
</>
);
}