ReactDOM使用相同的类来渲染多个元素?

时间:2016-10-13 13:36:34

标签: reactjs ecmascript-6 react-dom

我有多个元素使用相同的类并具有相同的内容。

所以我可以使用ReactDOM来渲染它们而不是:

ReactDOM.render(
    <Footer source="./data/nav.json"/>,
    document.getElementsByClassName('footer')[0] //mountNode
);

ReactDOM.render(
    <Footer source="./data/nav.json"/>,
    document.getElementsByClassName('footer')[1] //mountNode
);

ReactDOM.render(
    <Footer source="./data/nav.json"/>,
    document.getElementsByClassName('footer')[2] //mountNode
);

最好是我能动态地做,因为我不知道这些多个相同的元素有多少。

有可能吗?

修改

var elementLength = document.getElementsByClassName("footer").length;
if (elementLength > 0) {
    for (var i = 0; i < elementLength; i++) {
        ReactDOM.render(
            <Footer source="./data/nav.json"/>,
            document.getElementsByClassName('footer')[i] //mountNode
        );
    }
}

它会多次调用./data/nav.json

1 个答案:

答案 0 :(得分:5)

像(未经测试)的东西:

Array.prototype.forEach.call(
  document.getElementsByClassName('footer'),
  function(el) {
    ReactDOM.render(
      <Footer source="./data/nav.json"/>,
      el
    )
  }
)

编辑:现已测试