前言


  • 遗漏的常用组件,刚发现官方有提供,这边也来介绍一下。
  • 如本文有错或理解偏差欢迎联系我,会尽快改正更新!
  • 如有什么问题,也可直接通过邮箱 277511806@qq.com 联系我。

本章涉及资源下载:

链接: https://pan.baidu.com/s/1o84o6JS 密码: htx6

属性


  • animationType(动画类型) PropTypes.oneOf(['none', 'slide', 'fade'])

    • none:没有动画
    • slide:从底部滑入
    • fade:淡入视野
  • onRequestClose(被销毁时会调用此函数)Platform.OS ==='android'?PropTypes.func.isRequired:PropTypes.func

    • 在 'Android' 平台,必需使用此函数
  • onShow(模态显示的时候被调用)function

  • transparent (透明度) bool

    • true时,使用透明背景渲染模态。
  • visible(可见性) bool

    • 决定模态是否可见
  • onOrientationChange(方向改变时调用)PropTypes.func

    • 在模态方向变化时调用,提供的方向只是 '' 或 ''。在初始化渲染的时候也会调用,但是不考虑当前方向。
  • supportedOrientations(允许模态旋转到任何指定取向)PropTypes.arrayOf(PropTypes.oneOf(['portrait', 'portrait-upside-down', 'landscape','landscape-left','landscape-right']))

    • 在iOS上,模态仍然受 info.plist 中的 UISupportedInterfaceOrientations字段中指定的限制。

modal 基本使用


  • modal的使用很广泛,这边我们来看看怎么让视图以模态的形式展示:

    	export default class One extends Component {
    
    	    // 构造
    constructor(props) {
    super(props);
    // 初始状态
    this.state = {
    isModal:false
    };
    } showModal() {
    this.setState({
    isModal:true
    })
    } onRequestClose() {
    this.setState({
    isModal:false
    });
    } render() {
    return(
    <View style={styles.container}>
    {/* 初始化Modal */}
    <Modal
    animationType='slide' // 从底部滑入
    transparent={false} // 不透明
    visible={this.state.isModal} // 根据isModal决定是否显示
    onRequestClose={() => {this.onRequestClose()}} // android必须实现
    >
    <View style={styles.modalViewStyle}>
    {/* 关闭页面 */}
    <TouchableOpacity
    onPress={() => {{
    this.setState({
    isModal:false
    })
    }}}
    >
    <Text>关闭页面</Text>
    </TouchableOpacity>
    </View>
    </Modal> {/* 返回按钮 */}
    <TouchableOpacity
    onPress={() => {{
    this.props.navigator.pop()
    }}}
    >
    <Text>返回</Text>
    </TouchableOpacity> {/* 模态跳转 */}
    <TouchableOpacity
    onPress={() => this.showModal()}
    >
    <Text>模态跳转</Text>
    </TouchableOpacity>
    </View>
    );
    }
    }

modal 使用 —— 指示器


  • 这边我们再来做一个经常使用的功能 —— 指示器

    	export default class One extends Component {
    
    	    // 构造
    constructor(props) {
    super(props);
    // 初始状态
    this.state = {
    isModal:false
    };
    } showModal() {
    this.setState({
    isModal:true
    }) setTimeout(() => {
    this.setState({
    isModal:false
    });
    }, 1500)
    } onRequestClose() {
    this.setState({
    isModal:false
    });
    } render() {
    return(
    <View style={styles.container}>
    {/* 初始化Modal */}
    <Modal
    animationType='fade' // 淡入淡出
    transparent={true} // 透明
    visible={this.state.isModal} // 根据isModal决定是否显示
    onRequestClose={() => {this.onRequestClose()}} // android必须实现
    >
    <View style={styles.modalViewStyle}>
    <View style={styles.hudViewStyle}>
    <ActivityIndicator style={styles.chrysanthemumStyle}></ActivityIndicator>
    <Text style={styles.hudTextStyle}>加载中…</Text>
    </View>
    </View>
    </Modal> {/* 返回按钮 */}
    <TouchableOpacity
    onPress={() => {{
    this.props.navigator.pop()
    }}}
    >
    <Text>返回</Text>
    </TouchableOpacity> {/* 显示指示器 */}
    <TouchableOpacity
    onPress={() => this.showModal()}
    >
    <Text>显示指示器</Text>
    </TouchableOpacity>
    </View>
    );
    }
    }

总结


  • modal 的源码可以看出,modal 其实就是使用了 绝对定位,所以当 modal 无法满足我们的需求的时候,我们就可以通过 绝对定位 自己来封装一个 modal 了,对吧,时间关系,这边就不讲了,大伙自己试试就可以了。

React-Native 之 Modal介绍与使用的更多相关文章

  1. React Native之 ScrollView介绍和使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  2. React Native 之 Touchable 介绍与使用

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  3. React Native之FlexBox介绍和使用

    # 前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会 ...

  4. React Native项目组织结构介绍

    代码组织: 目录结构: . ├── components //组成应用的各个组件 │   ├── Routers.android.js //每个组件若实现不一样,分为android的实现和ios的实现 ...

  5. React Native 之 组件化开发

    前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...

  6. 使用Visual Studio Code和typescript 开发调试React Native项目

    关于React Native的详细介绍我就不叙述了,他是使用js构建原声app的开发框架.一次变异多平台运行,非常强大.但是个人不喜欢js的过于灵活(弱类型)的语法.强大的强类型语言Typescrip ...

  7. React Native 教程:001 - 如何运行官方控件示例 App

    原文发表于我的技术博客 本文主要讲解了如何运行 React Native 官方控件示例 App,包含了一些 React Native 的基础知识以及相关环境的配置. 原文发表于我的技术博客 React ...

  8. React Native从入门到放弃之环境搭建

    官网 https://facebook.github.io/react-native/ 中文网站 http://reactnative.cn/ 相关文档 http://www.lcode.org/史上 ...

  9. React Native创建一个APP

    React Native 结合了 Web 应用和 Native 应用的优势,可以使用 JavaScript 来开发 iOS 和 Android 原生应用.在 JavaScript 中用 React 抽 ...

  10. React Native v0.4 发布,用 React 编写移动应用

    React Native v0.4 发布,自从 React Native 开源以来,包括超过 12.5k stars,1000 commits,500 issues,380 pull requests ...

随机推荐

  1. Python源码剖析之准备工作

    一个Python程序开发者, 也是C语言爱好者, 为了加强自己对Python语言实现的理解, 最近选择阅读下陈儒老师的书, 对Python3.5.1源码进行阅读, 再次记录下读书笔记.  一.Pyth ...

  2. JDBC简单范例

    连接工具类 import java.sql.Connection; import java.sql.DriverManager; public class DBUtil { // 建立连接方法 pub ...

  3. Vijos P1127 级数求和【模拟】

    级数求和 描述 已知:Sn= 1+1/2+1/3+…+1/n.显然对于任意一个整数K,当n足够大的时候,Sn大于K. 现给出一个整数K(1<=k<=15),要求计算出一个最小的n:使得Sn ...

  4. 修改mysql密码的四种方法

    方法1: 用SET PASSWORD命令 首先登录MySQL. 格式:mysql> set password for 用户名@localhost = password('新密码'); 例子:my ...

  5. [国嵌攻略][142][LCD驱动程序架构]

    LCD裸机驱动回顾 1.LCD初始化 1.1.控制器初始化 1.2.端口初始化 1.3.指明了帧缓冲 2.LCD图形显示 2.1.将图形数据写入帧缓冲 Linux帧缓冲体验 把图片转换成开发板屏对应的 ...

  6. Spark算子--coalesce和repartition

    coalesce和repartition--Transformation类算子 代码示例

  7. Spark_总结一

    Spark_总结一 1.Spark介绍     1.1什么是Spark?     Apache Spark是一个开源的集群计算框架,使数据计算更快(高效运行,快速开发)          1.2Spa ...

  8. 本地apache 可以正常访问,lnmp服务器访问404错误

    if (!-e $request_filename) { rewrite  ^(.*)$  /index.php?s=/$1  last; break; }

  9. dede表前缀不定时,查询表#@__archives

    $query = "SELECT arc.*,tp.typedir,tp.typename,               tp.isdefault,tp.defaultname,tp.nam ...

  10. mysql 分组和聚合函数

    mysql 分组和聚合函数 Mysql 聚集函数有5个: 1.COUNT() 记录个数(count(1),count(*)统计表中行数,count(列名)统计列中非null数) 2.MAX() 最大值 ...