2016-06-26 12:30:58 -07:00
---
id: props
title: Props
layout: docs
category: The Basics
permalink: docs/props.html
next: state
2016-07-13 14:45:53 -07:00
previous: tutorial
2016-06-26 12:30:58 -07:00
---
Most components can be customized when they are created, with different parameters. These creation parameters are called `props` .
For example, one basic React Native component is the `Image` . When you
create an image, you can use a prop named `source` to control what image it shows.
```ReactNativeWebPlayer
import React, { Component } from 'react';
import { AppRegistry, Image } from 'react-native';
2017-05-16 23:43:46 -07:00
export default class Bananas extends Component {
2016-06-26 12:30:58 -07:00
render() {
let pic = {
uri: 'https://upload.wikimedia.org/wikipedia/commons/d/de/Bananavarieties.jpg'
};
return (
2016-06-29 05:00:47 -07:00
< Image source = {pic} style = {{width: 193 , height: 110 } } / >
2016-06-26 12:30:58 -07:00
);
}
}
2017-05-16 23:43:46 -07:00
// skip this line if using Create React Native App
2016-06-26 12:30:58 -07:00
AppRegistry.registerComponent('Bananas', () => Bananas);
```
Notice that `{pic}` is surrounded by braces, to embed the variable `pic` into JSX. You can put any JavaScript expression inside braces in JSX.
Your own components can also use `props` . This lets you make a single component
that is used in many different places in your app, with slightly different
properties in each place. Just refer to `this.props` in your `render` function. Here's an example:
```ReactNativeWebPlayer
import React, { Component } from 'react';
import { AppRegistry, Text, View } from 'react-native';
class Greeting extends Component {
render() {
return (
< Text > Hello {this.props.name}!< / Text >
);
}
}
2017-05-16 23:43:46 -07:00
export default class LotsOfGreetings extends Component {
2016-06-26 12:30:58 -07:00
render() {
return (
< View style = {{alignItems: ' center ' } } >
< Greeting name = 'Rexxar' / >
< Greeting name = 'Jaina' / >
< Greeting name = 'Valeera' / >
< / View >
);
}
}
2017-05-16 23:43:46 -07:00
// skip this line if using Create React Native App
2016-06-26 12:30:58 -07:00
AppRegistry.registerComponent('LotsOfGreetings', () => LotsOfGreetings);
```
Using `name` as a prop lets us customize the `Greeting` component, so we can reuse that component for each of our greetings. This example also uses the `Greeting` component in JSX, just like the built-in components. The power to do this is what makes React so cool - if you find yourself wishing that you had a different set of UI primitives to work with, you just invent new ones.
2017-01-31 12:07:15 -08:00
The other new thing going on here is the [`View` ](docs/view.html ) component. A [`View` ](docs/view.html ) is useful
2016-06-26 12:30:58 -07:00
as a container for other components, to help control style and layout.
2017-01-31 12:07:15 -08:00
With `props` and the basic [`Text` ](docs/text.html ), [`Image` ](docs/image.html ), and [`View` ](docs/view.html ) components, you can
build a wide variety of static screens. To learn how to make your app change over time, you need to [learn about State ](docs/state.html ).