Specifying a type for a function prop
A prop can be a function. In this lesson, we'll learn how to strongly-type function props.
We'll cover the following
Strongly-typing a render prop #
An example of a function prop is a prop that allows the consumer of a component to control the rendering of part of a component. This is called a render prop.
Open the CodeSandbox project we were working on in the last lesson. Let’s add a render prop to our Hello
component to optionally allow the consumer to control how the message is rendered. The prop will be called renderMessage,
and the Hello
component will be as follows:
const Hello = ({
who,
renderMessage,
message = "How are you?"
}: Props) => (
<React.Fragment>
<p>
Hello, {who.name}
{who.friend && " my friend"}
</p>
{message && (renderMessage ? renderMessage(message) : <p>{message}</p>)}
</React.Fragment>
);
An example consumption of Hello
is as follows:
<Hello
who={{ name: "Bob", friend: true }}
message="Hey, how are you?"
renderMessage={m => <i>{m}</i>}
/>
So, what should the definition of the Props
type be now with the new renderMessage
prop?
Get hands-on with 1300+ tech skills courses.