We can create a stylesheet by using StyleSheet.create. A stylesheet is a set of guidelines used to determine how a webpage or document is laid out and designed.
In order to style components of React Native app, we can use StyleSheet.create. StyleSheet in React Native shares several attributes with CSS, including color, height, top, right, bottom, and left. A StyleSheet in React Native is an abstraction resembling CSS StyleSheets.
Why StyleSheet.create is useful?
There are several ways to add styles to elements in React Native. Usage of inline styling and style through the use of a StyleSheet are two popular choices. The simplest approach to style any React application is via inline styles. We don’t need to make a separate CSS if you style elements inline. Inline styles are only a viable option for extremely small applications, despite a few immediate benefits.
As soon as our code base even significantly expands, the problems with inline styles become obvious. In order to get away with the cons of inline styles we use StyleSheet.create.
Syntax:
const styles = StyleSheet.create({
    container: {
        // Write CSS like property here.
        flex: 2,
        padding: 19,
        backgroundColor: "#123f45"
    }
},
Creating Application: Follow the below steps to create an application:
Step 1: Open your terminal and install expo-cli by the following command.
npm install -g expo-cli
Step 2: Now create a project by the following command.
expo init Project
Step 3: Now go into your project folder i.e. stylesheetdemo
cd Project
Project Structure: The project structure should look like this:
 
Initial Project Structure
Example 1: Below is the example, first we’ll see the output without using the StyleSheet.create:
App.js
Javascript
| import React from 'react'; import { Text, View, StyleSheet } from 'react-native';  const App = () => {     return(         <View >             <Text >                 GeeksForGeeks             </Text>         </View>     ); }; export defaultApp; | 
Steps to run the application: Write the below code in the terminal to run the application:
npm start or expo start
Output:
 
Initial Output
Now we will add styles to Text Component. We can do this by using StyleSheet.create. Here we are adding CSS-like properties eg. flex, padding, backgroundColor, margin, fontSize, fontWeight, textAlign, etc. Most of the properties are similar to CSS.
App.js
Javascript
| import React from 'react'; import { Text, View, StyleSheet } from 'react-native';  const App = () => {     return(         <View style={styles.container}>             <Text style={styles.paragraph}>                 GeeksForGeeks             </Text>         </View>     ); };  export defaultApp;  const styles = StyleSheet.create({     container: {         flex: 1,         justifyContent: 'center',         padding: 8,         backgroundColor: 'white',     },     paragraph: {         margin: 24,         fontSize: 18,         fontWeight: 'bold',         textAlign: 'center',         color: 'green'    }, }); | 
Output: Below is the output after applying the stylesheet is given below:
 
Output after applying the stylesheet
Example 2: In this Example, We are going to add multiple styles to Pressable (like a button), Text & View Component by using StyleSheet.create. We are using Pressable here in place of Button because the Button Component of React Native doesn’t accept style prop.
App.js
Javascript
| import React from 'react'; import { StyleSheet, Text, View, Pressable } from 'react-native';  export defaultfunctionApp() {     return(         <View style={styles.container}>             <View style={styles.box}>                 <Text style={styles.heading}>                     GeeksForGeeks</Text>                 <Text style={styles.paragraph}>                     This part is a text inthe paragraph.                      This is example of StyleSheet.create                 </Text>                 <Pressable style={styles.btn} >                     <Text style={styles.btnText}>                         Button                     </Text>                 </Pressable>             </View>         </View>     ); }  const styles = StyleSheet.create({     container: {         flex: 1,         backgroundColor: '#ebfaeb',         alignItems: 'center',         justifyContent: 'center',     },     box: {         height: 200,         width: 250,         overflow: 'hidden',         borderRadius: 10,         borderColor: "green",         borderWidth: 2,         margin: 24      },     heading: {         fontSize: 26,         padding: 10,         fontWeight: 'bold',         textAlign: 'center',         color: 'green'    },     paragraph: {         padding: 5,         fontSize: 14,         color: 'green',         justifyContent: 'center',         fontStyle: 'italic',         textAlign: 'center'    },     btn: {         alignItems: 'center',         justifyContent: 'center',         paddingVertical: 10,         paddingHorizontal: 15,         margin: 15,         borderRadius: 10,         elevation: 5,         backgroundColor: 'green',      },     btnText: {         color: 'aliceblue'    } }); | 
Output:
 
Example 2 Output
By using StyleSheet.create, we can easily add styling in React native component.


 
                                    







