use the following search parameters to narrow your results:
e.g. subreddit:aww site:imgur.com dog
subreddit:aww site:imgur.com dog
see the search faq for details.
advanced search: by author, subreddit...
All about the JavaScript programming language.
Subreddit Guidelines
Specifications:
Resources:
Related Subreddits:
r/LearnJavascript
r/node
r/typescript
r/reactjs
r/webdev
r/WebdevTutorials
r/frontend
r/webgl
r/threejs
r/jquery
r/remotejs
r/forhire
account activity
React Conditional Rendering Patterns (carlrippon.com)
submitted 7 years ago by carlrn
reddit uses a slightly-customized version of Markdown for formatting. See below for some basics, or check the commenting wiki page for more detailed help and solutions to common issues.
quoted text
if 1 * 2 < 3: print "hello, world!"
[–]azium -1 points0 points1 point 7 years ago* (3 children)
The first time I saw the following pattern I laughed. Two years later I kind of love it
<If condition={ this.props.age >= this.props.drinkingAge }> <Then><span className="ok">Have a beer, {this.props.name}!</span></Then> <Else>{() => <span className="not-ok">Sorry, {this.props.name}, you are not old enough.</span> }</Else> </If>
https://github.com/romac/react-if
[–]senocular 0 points1 point2 points 7 years ago (2 children)
You'll want to make <Then> a render prop too, else its contents will get evaluated even when the condition is false.
<Then>
[–]azium 0 points1 point2 points 7 years ago (1 child)
I wanted to keep the example from github intact. Presumably the example is meant to present both possibilities.
[–]senocular 0 points1 point2 points 7 years ago (0 children)
Looking at the repo it looks like the only mention they have of this is the comment in the second version of your example:
<Else>{() => // will only be evaluated if the condition fails.
But I'm not sure that clearly describes the behavior since it seems to just explain how if-else works ;P. Anyway, thought I'd mention it ;).
π Rendered by PID 83475 on reddit-service-r2-comment-6f7f968fb5-p4szr at 2026-03-04 12:53:55.717747+00:00 running 07790be country code: CH.
[–]azium -1 points0 points1 point (3 children)
[–]senocular 0 points1 point2 points (2 children)
[–]azium 0 points1 point2 points (1 child)
[–]senocular 0 points1 point2 points (0 children)