React Native 之 ToastAndroid(提示语)(二十一)

ToastAndroid 是 React Native 提供的一个特定于 Android 平台的

API,用于显示简单的消息提示(Toast)。

两个方法:

1. ToastAndroid.show(message, duration, gravity)

  • message: 要显示的文本消息。
  • duration: Toast 的持续时间,可以是 ToastAndroid.SHORT 或 ToastAndroid.LONG。
  • gravity (可选): Toast 的位置,如 ToastAndroid.TOP, ToastAndroid.BOTTOM, ToastAndroid.CENTER。但在 Android API 级别 30(R)及更高版本中,gravity 参数可能不再起作用,因为 Android 系统可能根据设备的设置和上下文自动确定 Toast 的位置。
javascript 复制代码
import React, { Component } from 'react';  
import { Button, ToastAndroid, Platform } from 'react-native';  
  
class ToastExample extends Component {  
  showToast = () => {  
    if (Platform.OS === 'android') {  
      ToastAndroid.show('Hello, 这是一个 Toast 消息!', ToastAndroid.SHORT);  
      // 如果你想使用 gravity 参数(在 API 级别 30 以下可能有效)  
      // ToastAndroid.show('Hello, 这是一个 Toast 消息!', ToastAndroid.LONG, ToastAndroid.CENTER);  
    }  
  };  
  
  render() {  
    return (  
      <Button  
        title="显示 Toast"  
        onPress={this.showToast}  
      />  
    );  
  }  
}  
  
export default ToastExample;

2. ToastAndroid.showWithGravity(message, duration, gravity, xOffset, yOffset)

  • message: 要显示的文本消息。
  • duration: Toast 的持续时间,可以是 ToastAndroid.SHORT 或 ToastAndroid.LONG。
  • gravity: Toast 的位置,如ToastAndroid.TOP(居上对齐),ToastAndroid.BOTTOM(居下对齐),ToastAndroid.CENTER(居中对齐)。
  • xOffset: 水平偏移量。
  • yOffset: 垂直偏移量。
javascript 复制代码
ToastAndroid.showWithGravity(  
  'Hello, 这是一个 Toast 消息!',  
  ToastAndroid.LONG,  
  ToastAndroid.BOTTOM,  
  0, // xOffset  
  50 // yOffset  
);

在React Native中,对于iOS平台,使用Alert API来显示消息提示框

Alert.alert( Title,Msg,arr,option)

  • Title:第一个参数是标题(Alert Title)。
  • Msg:第二个参数是消息内容(My Alert Msg)。
  • arr:第三个参数是一个数组,包含提示框中的按钮配置。每个按钮都是一个对象,具有text(按钮文本)、onPress(点击时执行的函数)和style(可选,用于指定按钮样式,如'cancel')等属性。
  • option:第四个参数是一个可选的配置对象,这里设置了cancelable为false,表示用户不能通过点击提示框外部来关闭它(在iOS上有效,Android上默认就不能通过点击外部关闭)。
javascript 复制代码
import React, { Component } from 'react';  
import { Button, Alert } from 'react-native';  
  
class AlertExample extends Component {  
  showAlert = () => {  
    Alert.alert(  
      'Alert Title',  
      'My Alert Msg',  
      [  
        {  
          text: 'Cancel',  
          onPress: () => console.log('Cancel Pressed'),  
          style: 'cancel',  
        },  
        {  
          text: 'OK',  
          onPress: () => console.log('OK Pressed'),  
        },  
      ],  
      { cancelable: false }  
    );  
  };  
  
  render() {  
    return (  
      <Button  
        title="显示消息提示"  
        onPress={this.showAlert}  
      />  
    );  
  }  
}  
  
export default AlertExample;
相关推荐
光头程序员4 小时前
grid 布局react组件可以循数据自定义渲染某个数据 ,或插入某些数据在某个索引下
javascript·react.js·ecmascript
limit for me4 小时前
react上增加错误边界 当存在错误时 不会显示白屏
前端·react.js·前端框架
浏览器爱好者4 小时前
如何构建一个简单的React应用?
前端·react.js·前端框架
VillanelleS7 小时前
React进阶之高阶组件HOC、react hooks、自定义hooks
前端·react.js·前端框架
eason_fan8 小时前
分析vue3源码23(异步组件实现)
vue.js·前端框架·源码阅读
傻小胖8 小时前
React 中hooks之useInsertionEffect用法总结
前端·javascript·react.js
有来技术16 小时前
从0到1构建开源 vue-uniapp-template:使用 UniApp + Vue3 + TypeScript 和 VSCoe、CLI 开发跨平台移动端脚手架
前端框架
flying robot17 小时前
React的响应式
前端·javascript·react.js
GISer_Jing1 天前
React+AntDesign实现类似Chatgpt交互界面
前端·javascript·react.js·前端框架
智界工具库1 天前
【探索前端技术之 React Three.js—— 简单的人脸动捕与 3D 模型表情同步应用】
前端·javascript·react.js