Native reagieren - Modal

In diesem Kapitel zeigen wir Ihnen, wie Sie die modale Komponente in React Native verwenden.

Lassen Sie uns jetzt eine neue Datei erstellen: ModalExample.js

Wir werden Logik hineinstecken ModalExample. Wir können den Ausgangszustand aktualisieren, indem wir das ausführentoggleModal.

Nach dem Aktualisieren des Ausgangszustands durch Ausführen von toggleModalwerden wir das einstellen visibleEigentum an unserem Modal. Diese Requisite wird aktualisiert, wenn sich der Status ändert.

Das onRequestClose wird für Android-Geräte benötigt.

App.js.

import React, { Component } from 'react'
import WebViewExample from './modal_example.js'

const Home = () => {
   return (
      <WebViewExample/>
   )
}
export default Home;

modal_example.js

import React, { Component } from 'react';
import { Modal, Text, TouchableHighlight, View, StyleSheet}

from 'react-native'
class ModalExample extends Component {
   state = {
      modalVisible: false,
   }
   toggleModal(visible) {
      this.setState({ modalVisible: visible });
   }
   render() {
      return (
         <View style = {styles.container}>
            <Modal animationType = {"slide"} transparent = {false}
               visible = {this.state.modalVisible}
               onRequestClose = {() => { console.log("Modal has been closed.") } }>
               
               <View style = {styles.modal}>
                  <Text style = {styles.text}>Modal is open!</Text>
                  
                  <TouchableHighlight onPress = {() => {
                     this.toggleModal(!this.state.modalVisible)}}>
                     
                     <Text style = {styles.text}>Close Modal</Text>
                  </TouchableHighlight>
               </View>
            </Modal>
            
            <TouchableHighlight onPress = {() => {this.toggleModal(true)}}>
               <Text style = {styles.text}>Open Modal</Text>
            </TouchableHighlight>
         </View>
      )
   }
}
export default ModalExample

const styles = StyleSheet.create ({
   container: {
      alignItems: 'center',
      backgroundColor: '#ede3f2',
      padding: 100
   },
   modal: {
      flex: 1,
      alignItems: 'center',
      backgroundColor: '#f7021a',
      padding: 100
   },
   text: {
      color: '#3f2949',
      marginTop: 10
   }
})

Unser Startbildschirm wird so aussehen -

Wenn wir auf die Schaltfläche klicken, wird das Modal geöffnet.