您的位置:首页 > Web前端 > React

react-native自定义Modal模态框|仿ios、微信弹窗RN版

2019-08-03 03:41 344 查看

前序

纵观每个优质项目,无论web端还是native原生应用开发,弹窗都是不可忽视的一环,能很大程度上直接决定用户体验。如:微信、支付宝、ios都有很成熟的一套弹窗UI展示场景。

最近一直沉迷在react-native开发研究中,学习起来发现没有想象的难,不过也采坑了不少。鉴于之前有基于h5和小程序技术开发过自定义弹窗的经验,就想着用react-native技术实现msg信息框|alert提示框|confirm确认框|toast弱提示/loading|仿ios、android弹窗,就有了这个rnPop弹窗组件RN版。

效果图

仿真模拟器上画质有些次,真机实测完美,可忽略这一点

看了上图,是不是觉得调用方式还挺多的,没错,很丰富的应用场景

◆ rnPop弹窗组件目录结构

◆ 引入方式及调用

import RNPop from '../utils/rnPop/rnPop.js'

显示:this.refs.rnPop.show({...options}); 隐藏:this.refs.rnPop.hide();
/**
* --------- react-native弹窗演示(普通型弹窗) ---------
*/
//msg提示
handlePress01 = ()=> {
let rnPop = this.refs.rnPop
rnPop.show({
anim: 'fadeIn',
content: 'msg消息提示框(5s后窗口关闭)',
shade: true,
shadeClose: false,
time: 5,
xtime: true,
});
}

//msg提示(黑色背景)
handlePress02 = ()=> {
let rnPop = this.refs.rnPop
rnPop.show({
content: '自定义弹窗背景',
shade: false,
style: {backgroundColor: 'rgba(17,17,17,.7)', borderRadius: 6},
contentStyle: {color: '#fff', padding: 10},
time: 2
});
}

toast弱提示可自定义loading | success | info | error四种图标

//Toast演示
handlePress15 = ()=> {
let rnPop = this.refs.rnPop
rnPop.s
ad8
how({
skin: 'toast',
content: '操作成功',
icon: 'success', //success | info | error | loading
shade: false,
time: 3
});
}
//ios居中对话框
handlePress17 = ()=> {
let rnPop = this.refs.rnPop
rnPop.show({
skin: 'footer',
position: 'center',
content: '如果您喜欢探鱼,请给我们个好评,也可以直接反馈意见给我们!',
shadeClose: true,

btns: [
{
text: '给个好评',
style: {color: '#30a4fc'},
onPress() {
console.log('您点击了给个好评!');

//回调函数
rnPop.show({
anim: 'fadeIn',
content: '感谢您的好评,我们会再接再厉!',
shade: true,
time: 3
});
}
},
{
text: '不好用,我要提意见',
style: {color: '#30a4fc'},
onPress() {
// ...
}
},
{

56c
text: '残忍的拒绝',
style: {color: '#30a4fc'},
onPress() {
rnPop.close();
}
}
]
});
}

/**
* @Title         react-native弹窗插件 rnPop-v1.0 beta (UTF-8)
* @Author        andy
* @Create        2019/07/30 10:00:50 GMT+0800 (中国标准时间)
* @AboutMe    Q:282310962  wx:xy190310
*/

'use strict'

import React, {Component} from 'react'
import {
StyleSheet, Dimensions, PixelRatio, TouchableHighlight, Modal, View, Text, Image, ActivityIndicator, Alert
} from 'react-native'

const pixel = PixelRatio.get()
const {width, height} = Dimensions.get('window')

export default class RNPop extends Component{
/**************************
*    弹窗配置参数
*/
static defaultProps = {
isVisible: false,       //弹窗显示

id: 'rnPop',            //弹窗id标识
title: '',              //标题
content: '',            //内容
style: null,            //自定义弹窗样式 {object}
contentStyle: null,     //内容样式
skin: '',               //自定义弹窗风格
icon: '',               //自定义弹窗图标

shade: true,            //遮罩层
shadeClose: true,       //点击遮罩层关闭
opacity: '',            //遮罩层透明度
xclose: false,          //自定义关闭按钮
time: 0,                //弹窗自动关闭秒数
xtime: false,           //显示关闭秒数

anim: 'scaleIn',        //弹窗动画
follow: null,            //跟随定位(适用于在长按位置定位弹窗)
position: '',           //弹窗位置
zIndex: 9999,           //层叠等级

btns: null,             //弹窗按钮(不设置则不显示按钮)[{...options}, {...options}]
}

constructor(props){
super(props)
this.state = { ...this.props }
this.timer = null
}

render(){
let opt = this.state

// 自定义toast图标
let slotImg = {
success: require('./skin/success.png'),
error: require('./skin/error.png'),
info: require('./skin/info.png'),
}

...

}

/**************************
*    显示弹窗事件(处理传参)
*/
show = (args) => {
this.setState({
...this.props, ...args, isVisible: true
})
}

/**************************
*    关闭弹窗事件
*/
close = () => {
console.log('关闭')
this.setState({
...this.props
})
this.timer && clearTimeout(this.timer)
delete this.timer
}
}

◆ react-native自定义弹窗模板

<Modal transparent={true} visible={opt.isVisible} onRequestClose={this.close}>
<View style={styles.rnpop__ui_panel}>
{/* 遮罩 */}
{ opt.shade && <View style={styles.rnpop__ui_mask} onTouchEnd={opt.shadeClose ? this.close : null} /> }
{/* 窗体 */}
<View style={styles.rnpop__ui_main}>
<View style={styles.rnpop__ui_child}>
{/* 标题 */}
{ opt.title ? <View style={[styles.rnpop__ui_tit]}><Text style={[styles.rnpop__ui_titxt]}>{opt.title}</Text></View> : null }
{/* 内容 */}
{ opt.content ? <View style={[styles.rnpop__ui_cnt]}>
...
<Text style={[styles.rnpop__ui_cntxt, opt.contentStyle]}>{opt.content}</Text>
</View> : null }
{/* 按钮 */}
<View style={[styles.rnpop__ui_btnwrap]}>
...
</View>
</View>
</View>
</View>
</Modal>

◆ 附上之前的h5和小程序弹窗

h5手机端弹窗:https://www.cnblogs.com/xiaoyan2017/p/8695783.html

h5网页版弹窗:https://www.cnblogs.com/xiaoyan2017/p/10227798.html

小程序弹窗:https://www.geek-share.com/detail/2753477660.html

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: