reason-react
reason-react copied to clipboard
Array of children not allowed
I'm quite new to ReasonReact. So, there's a good chance I've just missed something, but I've been trying to figure out how to pass an array of children to a component and haven't been able to figure it out. This is what I've made:
and this is the error I'm getting from it
data:image/s3,"s3://crabby-images/124d4/124d464f7909d2659b7378535ca7c4b2219f6f81" alt="Screen Shot 2020-10-06 at 4 32 10 PM"
What's even more confusing is that if I manually pass multiple children:
Everything is all good:
data:image/s3,"s3://crabby-images/a396e/a396e82a9b65024236171af4824749aefd49f40e" alt="Screen Shot 2020-10-06 at 4 41 18 PM"
Is this intended behavior, and if so, how do I pass a generated array of children to a component?
Could you try to wrap your array of children in React.array
, for example:
module Button = {
@react.component
let make = (~buyLinks: array<string>) => {
<div>
{React.array(Array.map(name => <a> {React.string(name)} </a>, buyLinks))}
</div>
}
}
Worked like a charm! Thank you. Also, just out of curiosity, is this documented somewhere? If not, I'd highly recommend adding a note about it since it's a very common use-case.
It took me like a year to find out that React.array
exists.
It's on the first section of the docs for "Core" @banacorn (https://reasonml.github.io/reason-react/docs/en/components)
Maybe we should have a separate section for this precise error?
I'm closing this, but might be able to fix this soon.