React Native:Tutorial #4 – React Native UI Components

In this blog post, we will learn few commonly used React Native UI Components. We can use different types of UI elements in a react-native project. But remember that it may look different in an android and iPhone. We will learn how text inputs, touchables and picker with different examples.

If you have not read previous articles in this series, we request you to do so-

Tutorial Index

  1. Tutorial #1 – React Native – Introduction
  2. Tutorial #2 – React Native Props and State
  3. Tutorial #3 – Styling React Native App
  4. Tutorial #4 – React Native UI Components
  5. Tutorial #5 – React Native API Integration
  6. Tutorial #6 – React Native Animation
  7. Tutorial #7 – Top 10 React Native libraries

Text Inputs:

TextInput component is used to get user text inputs. Following are the props that can be used with text inputs : placeholder : That’s the placeholder text i.e. the text that will be shown in an empty TextInput. value : Value to put in the TextInput onChangeText : It takes one function and that will be called on each text change . onSubmitEditing : It takes one function and that will be called once text is submitted.

Let’s take a look at the below example :

If you type any text in the TextInput, it will show the same text below in a Text. ‘placeholder’ props is used to put the placeholder. That is removed once user starts to type. The onChangeText props takes one function and it change the value of ‘text’ in the current ‘state’. ‘value’ props is used to put the text in the TextInput. We are not directly changing the ‘value’ of the ‘TextInput’. It changes the value of ‘text’ in the ‘state’ and that ‘text’ is assigned as the value. The bottom ‘Text’ is used to put the same text that the user is typing.

TextInput has a lot of other props for customization. You can check this official guide to learn more about it.

Touch Handling:

All mobile applications are handled mainly using finger touch. These touch gestures can be of different types like tap, swipe, pinch etc. React native provides one gesture responder system to handle different gestures. Almost all react native component can detect user finger tap, but one component that is only for deal with touch event is called ‘Touchables’. Using this component, we can create our own custom buttons with different design. It also provides two different props to detect single press and long press events. Following are the types of feedbacks it can provide :

TouchableHighlight :

This can be used with a button or web-link. The view will be darkened when the user presses down the element.

TouchableNativeFeedback :

This will show ripple effect on Android. TouchableNativeFeedback is not supported on iOS.

TouchableOpacity :

This will reduce the opacity of the button when user presses down.

TouchableWithoutFeedback :

Use it if you don’t want to show any feedback to the user on tap.

Apart from these types, we can use ‘onPress’ and ‘onLongPress’ props to detect single press and long press. Both of these props takes one ‘function’.

As you can see here, we are using ‘onPress’ and ‘onLongPress’ props to detect single press and long press in the TouchableHighlight component.

Picker:

Picker is used to ask user to pick from a list of values. Picker component is available in both Android and iOS. The functionality is same in both Android and iOS but the look is different. Actually it uses the native Android and iOS pickers and both looks different. It shows the selected value and once we click on it, it shows a list of available values in a popup in android. In iOS, it shows one scrollable wheel with all the options available. We can import the Picker component from ‘react-native’ as like other components. For example :

If you run this code, it will look like as below on an Android phone :

We need to add a list of items as ‘Picker.Item’ inside the ‘Picker’ component that will be shown in the picker list. Picker has a lot of different props. Few of them are as below :

1. onValueChange :

It gives one callback when one item is selected from the picker. It gives the value of the selected item and the index of that item. Index is important, we can pick from a different mapping list using the index if required.

2. selectedValue :

Selected value that should be matched with one of the list of picker item values.

3. enabled :

It will disable the picker if we set the value to ‘false’.

4. mode :

This option is available only for Android. It can be either ‘dialog’ or ‘dropdown’. ‘dialog’ shows a modal dialog, that’s the default option. ‘dropdown’ shows a dropdown view.

5. style and itemstyle :

style should be of type ‘pickerStyleType’. It’s used to add one ‘style’ to the ‘picker’. ‘itemStyle’ is used to apply style to each of the item labels.

Conclusion

So far we have seen most commonly used React Native UI Components that are required by most apps. Please let us know your views, questions about the same.

Tutorial Index

  1. Tutorial #1 – React Native – Introduction
  2. Tutorial #2 – React Native Props and State
  3. Tutorial #3 – Styling React Native App
  4. Tutorial #4 – React Native UI Components
  5. Tutorial #5 – React Native API Integration
  6. Tutorial #6 – React Native Animation
  7. Tutorial #7 – Top 10 React Native libraries

Source: https://www.opencodez.com/react-native/react-native-ui-components.htm


You might also like this video