React Native开发封装Toast与加载Loading组件示例


Posted in Javascript onSeptember 08, 2018

在App开发中,我们避免不了使用的两个组件,一个Toast,一个网络加载Loading,在RN开发中,也是一样,React Native官方并没有提供者这两个常用组件,需要开发者自己根据需求来自定义。作者就在其他组件的基础上在进行二次封装,使用起来更加简单,更具扩展性,同学们只需将Toast与Loading文件拖到项目中,install对应的组件库即可

效果图

React Native开发封装Toast与加载Loading组件示例 

Toast和Loading Demo地址

https://github.com/guangqiang-liu/react-native-toastAndLoading

Demo使用使用到的三方组件

  • react-native-root-toast:用来显示
  • toast react-native-root-siblings:用来Loading在App最上层添加视图
  • react-native-vector-icons:IconFont

注意

react-native-vector-icons 需要link 才能使用,同学们需要注意

Toast组件

toast组件这里作者分类8种不同的使用场景,目前能想到的就这多场景了,后面同学们有其他场景,可以自行添加即可,Toast组件中使用到的Icon图标,同学们也可以自行修改

  • 只显示最简单的文本的toast
  • 只显示最简单的文本的长toast,显示时长 + 500毫秒
  • 显示success的toast,success的Toast带有一个成功的对号icon
  • 显示success的toast,支持回调,使用场景类似于登录成功,显示1500毫秒toast,然后在回调函数中跳转到其他页面
  • 显示success的长toast,显示时长 + 500毫秒
  • 显示success的长toast,显示时长 + 500毫秒,支持回调,使用场景类似于登录成功,显示1000毫秒toast,然后跳转到其他页面
  • 显示warning的toast,使用场景类似于登录表单,手机号填写错误
  • 显示报错的toast,使用场景类似于登录表单,提交表单失败

 Loading组件

Loading组件最常用的使用场景就是网络请求时,数据还没有请求回来之前,页面最上层显示一个正在加载的loading框,一来能够防止用户在网络请求时又做其他的操作,二来可以给用户一个更好的体验,不至于页面空白,显得突兀

  1. loading支持手动调用显示:show()
  2. 支持手动关闭显示:hidden()

这里作者建议使用redux来控制Loading的显示与隐藏,这样不用在每一个需要网络请求的页面都手动去调用显示与隐藏,更高端的Loading使用技巧可以参照作者的 https://github.com/guangqiang-liu/OneM

Toast核心源码

const Toast = {

 toast: null,

 show: msg => {
 this.toast = RootToast.show(msg, {
 position: 0,
 duration: 1500
 })
 },

 showLong: msg => {
 this.toast = RootToast.show(msg, {
 position: 0,
 duration: 2000
 })
 },

 showSuccess: (msg, options) => {
 let toast = RootToast.show(
 Platform.OS === 'ios' ?
 <View style={styles.container}>
  <Icon name='check' size={50} color={'#fff'}/>
  <Text style={styles.message}>{msg}</Text>
 </View> : msg, {
 duration: 1500,
 position: RootToast.positions.CENTER,
 ...options,
 })
 setTimeout(function () {
 RootToast.hide(toast)
 typeof options === 'function' ? options && options(): null
 }, 2000)
 },

 showLongSuccess: (msg, options) => {
 let toast = RootToast.show(
 Platform.OS === 'ios' ?
 <View style={styles.container}>
  <Icon name='check' size={50} color={'#fff'}/>
  <Text style={styles.message}>{msg}</Text>
 </View> : msg, {
 duration: 2000,
 position: RootToast.positions.CENTER,
 ...options,
 })
 setTimeout(function () {
 RootToast.hide(toast)
 typeof options === 'function' ? options && options(): null
 }, 2500)
 },

 showWarning: (msg, options) => {
 let toast = RootToast.show(
 Platform.OS === 'ios' ?
 <View style={styles.container}>
  <Icon name='warning' size={40} color={'#fff'}/>
  <Text style={styles.message}>{msg}</Text>
 </View> : msg, {
 duration: RootToast.durations.SHORT,
 position: RootToast.positions.CENTER,
 ...options,
 })
 setTimeout(function () {
 RootToast.hide(toast)
 }, RootToast.durations.SHORT + 500)
 },

 showError: (msg, options) => {
 let toast = RootToast.show(
 Platform.OS === 'ios' ?
 <View style={styles.container}>
  <Icon name='close' size={40} color={'#fff'}/>
  <Text style={styles.message}>{msg}</Text>
 </View> : msg, {
 duration: RootToast.durations.SHORT,
 position: RootToast.positions.CENTER,
 ...options,
 })
 setTimeout(function () {
 RootToast.hide(toast)
 }, RootToast.durations.SHORT + 500)
 }

}

Loading核心源码

const HUD = {

 show: () => {
 sibling = new RootSiblings(
 <View style={styles.maskStyle}>
 <View style={styles.backViewStyle}>
  <ActivityIndicator size="large" color="white" />
 </View>
 </View>
 )
 },

 hidden: ()=> {
 if (sibling instanceof RootSiblings) {
 sibling.destroy()
 }
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javaScript 删除字符串空格多种方法小结
Oct 24 Javascript
jquery实现按Enter键触发事件示例
Sep 10 Javascript
JQuery验证jsp页面属性是否为空(实例代码)
Nov 08 Javascript
IE下使用jQuery重置iframe地址时内存泄露问题解决办法
Feb 05 Javascript
基于JS组件实现拖动滑块验证功能(代码分享)
Nov 18 Javascript
JavaScript高阶函数_动力节点Java学院整理
Jun 28 Javascript
Vue.js2.0中的变化小结
Oct 24 Javascript
创建echart多个联动的示例代码
Nov 23 Javascript
如何用RxJS实现Redux Form
Dec 29 Javascript
vue+element+Java实现批量删除功能
Apr 08 Javascript
JavaScript Dom实现轮播图原理和实例
Feb 19 Javascript
Vue深入理解插槽slot的使用
Aug 05 Vue.js
原生JS实现前端本地文件上传
Sep 08 #Javascript
JS实现可视化文件上传
Sep 08 #Javascript
js实现文件上传功能 后台使用MultipartFile
Sep 08 #Javascript
vue-router的HTML5 History 模式设置
Sep 08 #Javascript
vue移动端下拉刷新和上拉加载的实现代码
Sep 08 #Javascript
react 父子组件之间通讯props
Sep 08 #Javascript
js代码规范之Eslint安装与配置详解
Sep 08 #Javascript
You might like
php代码优化及php相关问题总结
2006/10/09 PHP
PHP 选项及相关信息函数库
2006/12/04 PHP
php+mysql 实现身份验证代码
2010/03/24 PHP
php入门学习知识点八 PHP中for循环基本应用之九九乘法口绝表
2011/07/14 PHP
php生成zip压缩文件的方法详解
2013/06/09 PHP
jQuery+php实现ajax文件即时上传的详解
2013/06/17 PHP
php用header函数实现301跳转代码实例
2013/11/25 PHP
yii框架通过控制台命令创建定时任务示例
2014/04/30 PHP
列举PHP的Yii 2框架的开发优势
2015/07/03 PHP
ThinkPHP框架实现定时执行任务的两种方法分析
2018/09/04 PHP
laravel框架使用FormRequest进行表单验证,验证异常返回JSON操作示例
2020/02/18 PHP
JQuery Easyui Tree的oncheck事件实现代码
2010/05/28 Javascript
Js sort排序使用方法
2011/10/17 Javascript
js简单实现删除记录时的提示效果
2013/12/05 Javascript
nodejs修复ipa处理过的png图片
2016/02/17 NodeJs
jquery hover 不停闪动问题的解决方法(亦为stop()的使用)
2017/02/10 Javascript
深入理解Vue Computed计算属性原理
2018/05/29 Javascript
新手必须知的Node.js 4个JavaScript基本概念
2018/09/16 Javascript
详解ES6系列之私有变量的实现
2018/11/21 Javascript
JavaScript命名空间模式实例详解
2019/06/20 Javascript
微信小程序如何连接Java后台
2019/08/08 Javascript
java遇到微信小程序 &quot;支付验证签名失败&quot; 问题解决
2019/12/22 Javascript
JavaScript鼠标拖拽事件详解
2020/04/03 Javascript
py2exe 编译ico图标的代码
2013/03/08 Python
python dataframe 输出结果整行显示的方法
2018/06/14 Python
Python3使用SMTP发送带附件邮件
2020/06/16 Python
实例介绍Python中整型
2019/02/11 Python
python环境搭建和pycharm的安装配置及汉化详细教程(零基础小白版)
2020/08/19 Python
巴西手表购物网站:eclock
2019/03/19 全球购物
建筑系毕业生自我鉴定
2014/01/24 职场文书
保护母亲河倡议书
2014/04/14 职场文书
讲文明树新风演讲稿
2014/05/12 职场文书
花坛标语大全
2014/06/30 职场文书
2015小学毕业班工作总结
2015/07/21 职场文书
使用Java去实现超市会员管理系统
2022/03/18 Java/Android
Oracle查看表空间使用率以及爆满解决方案详解
2022/07/23 Oracle