How to Create Multiple Select Checkbox in React Native?

04-Apr-2023

.

Admin

How to Create Multiple Select Checkbox in React Native?

Hi Guys,

Here, I will show you how to create multiple select checkbox in react native. step by step explain react native multiple select checkbox example. This post will give you simple example of how to implement multiple select checkbox in react native. you will learn multiple select checkbox in react native. Here, Creating a basic example of how to use multiple select checkbox in react native.

Let's start following example:

Step 1: Download Project


In the first step run the following command to create a project.

expo init ExampleApp

Step 2: Install Expo Icons

You install expo vector icons to create checkbox:

npm install @expo/vector-icons

import this:

import { MaterialCommunityIcons } from "@expo/vector-icons";

Step 3: App.js

In this step, You will open the App.js file and put the code.

import React from 'react';

import { StyleSheet, Text, View, Pressable, StatusBar, FlatList } from 'react-native';

import { MaterialCommunityIcons } from "@expo/vector-icons";

import { Card } from 'react-native-paper';

import Constants from 'expo-constants';

const data = [

{ id: 1, txt: 'React Native', isChecked: false },

{ id: 2, txt: 'Javascript', isChecked: false },

{ id: 3, txt: 'Laravel', isChecked: false },

{ id: 4, txt: 'PHP', isChecked: false },

{ id: 5, txt: 'jQuery', isChecked: false },

{ id: 6, txt: 'Boostrap', isChecked: false },

{ id: 7, txt: 'HTML', isChecked: false },

];

const App = () => {

const [products, setProducts] = React.useState(data);

const handleChange = (id) => {

let temp = products.map((product) => {

if (id === product.id) {

return { ...product, isChecked: !product.isChecked };

}

return product;

});

setProducts(temp);

};

let selected = products.filter((product) => product.isChecked);

const renderFlatList = (renderData) => {

return (

<FlatList

data={renderData}

renderItem={({ item }) => (

<Card style={{ margin: 5 }}>

<View style={styles.card}>

<View

style={{

flexDirection: 'row',

flex: 1,

justifyContent: 'space-between',

}}>

<Pressable onPress={() => handleChange(item.id)} >

<MaterialCommunityIcons

name={item.isChecked ? 'checkbox-marked' : 'checkbox-blank-outline'} size={24} color="#000" />

</Pressable>

<Text>{item.txt}</Text>

</View>

</View>

</Card>

)}

/>

);

}

return (

<View style={styles.container}>

<View style={{ flex: 1 }}>

{renderFlatList(products)}

</View>

<Text style={styles.text}>Selected </Text>

<View style={{ flex: 1 }}>

{renderFlatList(selected)}

</View>

<StatusBar />

</View>

);

}

const styles = StyleSheet.create({

container: {

flex: 1,

justifyContent: 'center',

paddingTop: Constants.statusBarHeight,

backgroundColor: '#ecf0f1',

padding: 8,

},

card: {

padding: 10,

margin: 5,

flexDirection: 'row',

justifyContent: 'space-between',

},

modalView: {

margin: 20,

backgroundColor: 'white',

borderRadius: 20,

padding: 5,

justifyContent: 'space-between',

alignItems: 'center',

elevation: 5,

},

text: {

textAlign: 'center',

fontWeight: 'bold',

},

});

export default App;

Run Project

In the last step run your project using the below command.

expo start

You can QR code scan in Expo Go Application on mobile.

Output :

It will help you...

#React Native