{Alert.alert("Modalhasbeenclosed.");}}>YourContentHere要使用模態元件,您需要先導入它,如下所示-import{Modal}fr"/> {Alert.alert("Modalhasbeenclosed.");}}>YourContentHere要使用模態元件,您需要先導入它,如下所示-import{Modal}fr">

首頁 >web前端 >js教程 >解釋 React Native 中模態視窗的工作原理

解釋 React Native 中模態視窗的工作原理

PHPz
PHPz轉載
2023-08-24 15:01:01859瀏覽

模態元件有助於在 UI 內容上方顯示內容視圖。

基本模態元件如下-

<Modal animationType="slide" transparent={true} visible={modalVisible} onRequestClose={() => { Alert.alert("Modal has been closed."); }}> Your Content Here</Modal>

要使用模態元件,您需要先匯入它,如下所示-

import { Modal } from "react-native";

模態視窗的基本屬性如下-

Sr.No 道具與說明
1 animationType

此屬性處理顯示的動畫 模態視窗。它是一個具有三個值的枚舉 - 滑動、淡入淡出和無。

2 onDismiss

該屬性接受一個將被呼叫的函數 當模態視窗關閉時。

3 onOrientationChange

裝置啟動時呼叫的回呼函數 當模態視窗改變方向時 顯示。

4 onShow

函數傳遞為稱為的 prop 值 當顯示模態視窗時。

5 presentationStyle

該屬性處理模態方塊的顯示 窗戶。可用的值是全屏, pageSheet、formSheet 和 overFullScreen。

6 透明

#該道具將決定提供透明視圖或填充 模式視窗的整個視圖。

7 visibile##這個屬性將決定你的模態視窗是否是 可見或不可見。

範例1:顯示模態視窗顯示

要使用模態元件,您需要先匯入它,如下所示-

import { Modal } from "react-native";

要顯示模式窗口,您可以決定要在其上顯示的動畫。選項有滑動、淡入淡出和無。在下面的範例中,我們想要顯示一個簡單的模式窗口,上面有文字和按鈕,如下所示 -

<Modal
      animationType="slide"
      transparent={true}
      visible={isVisible}
   >
   <View style={styles.centeredView}>
      <View style={styles.myModal}>
         <Text style={styles.modalText}>Modal Window Testing!</Text>
            <Button style={styles.modalButton} title="Close" onPress={() => {setModalVisiblility(false); }}/>
      </View>
   </View>
</Modal>

isVisible 變數被指派給可見屬性。預設為 false,即預設情況下不會顯示模式視窗。 isVisible 屬性的初始化如下所示 -

const [isVisible, setModalVisiblility] = useState(false);

setModalVisiblility 會將 isVisible 變數從 false 更新為 true,反之亦然。

元件中定義的關閉按鈕呼叫 setModalVisiblility(false),這將使 isVisible 為 false,並且模式視窗將消失。

要顯示模態窗口,

元件外部有一個按鈕呼叫 setModalVisiblility(true),如下所示 -

<View style={styles.centeredView}>
   <Modal
      animationType="slide"
      transparent={true}
      visible={isVisible}
   >
   <View style={styles.centeredView}>
      <View style={styles.myModal}>
         <Text style={styles.modalText}>Modal Window Testing!</Text>
            <Button style={styles.modalButton} title="Close" onPress={() =>{setModalVisiblility(false); }}/>
            </View>
         </View>
      </Modal>
      <Button title="Click Me" onPress={() => {
         setModalVisiblility(true);
      }}
   />
</View>

這是顯示/隱藏模式視窗的工作程式碼。

import React, { useState } from "react";
import { Button, Alert, Modal, StyleSheet, Text, View } from "react-native";
const App = () => {
   const [isVisible, setModalVisiblility] = useState(false);
   return (
      <View style={styles.centeredView}>
         <Modal
            animationType="slide"
            transparent={true}
            visible={isVisible}
         >
         <View style={styles.centeredView}>
            <View style={styles.myModal}>
               <Text style={styles.modalText}>Modal Window Testing!</Text>
                  <Button style={styles.modalButton} title="Close" onPress={() =>{setModalVisiblility(false); }}/>
                  </View>
               </View>
            </Modal>
            <Button title="Click Me" onPress={() => {
               setModalVisiblility(true);
            }}
         />
      </View>
   );
};
const styles = StyleSheet.create({
   centeredView: {
      flex: 1,
      justifyContent: "center",
      alignItems: "center",
      marginTop: 22
   },
   myModal: {
      width:200,
      height:200,
      margin: 20,
      backgroundColor: "white",
      borderRadius: 20,
      padding: 35,
      alignItems: "center",
      shadowColor: "#000",
      shadowOffset: {
         width: 0,
         height: 2
      },
      shadowOpacity: 0.30,
      shadowRadius: 4,
      elevation: 5
   },
   modalText: {
      marginBottom: 20,
      textAlign: "center"
   },
   modalButton: {
      marginBottom: 50,
   }
});
export default App;

輸出

解释 React Native 中模态窗口的工作原理#

以上是解釋 React Native 中模態視窗的工作原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除