In this example we introduce a basic React concept: handling properties.
We add a username property and display it in the hello component.
We take as startup point the example 01 Hello React:
- hello stateless component: create a property to hold the username value.
- Let's provide a value from our parent control.
Install Node.js and npm (v6.6.0) if they are not already installed on your computer.
Verify that you are running at least node v6.x.x and npm 3.x.x by running
node -v
andnpm -v
in a terminal/console window. Older versions may produce errors.
-
Copy the content from 01 HelloReact and execute:
npm install
-
Let's update hello.tsx to add a new property (userName) and display it using interpolation ({userName}):
hello.tsx
import * as React from 'react';
- export const HelloComponent = () => {
+ export const HelloComponent = (props: {userName : string}) => {
return (
- <h2>Hello component !</h2>
+ <h2>Hello user: { props.userName } !</h2>
);
}
Side note: using interfaces and ES6, the change looks like this:
import * as React from 'react';
+ interface Props {
+ username: string;
+ }
- export const HelloComponent = () => {
+ export const HelloComponent = (props: Props) => (
- return (
- <h2>Hello component !</h2>
+ <h2>Hello user: { props.userName } !</h2>
);
-}
- Let's update main.tsx and provide a value to the userName property:
import * as React from 'react';
import * as ReactDOM from 'react-dom';
import { HelloComponent } from './hello';
ReactDOM.render(
- <HelloComponent />,
+ <HelloComponent userName="John" />,
document.getElementById('root')
);
- Let's test the sample:
npm start