React Native封装Toast与加载Loading组件
React Native开发封装Toast与加载Loading组件在App开发中,我们避免不了使用的两个组件,一个Toast,一个网络加载Loading,在RN开发中,也是一样,React Native官方并没有提供者这两个常用组件,需要开发者自己根据需求来自定义。作者就在其他组件的基础上在进行二次封装,使用起来更加简单,更具扩展性,同学们只需将Toast与Loading文件拖到项目中,install对应的组件库即可 效果图Toast和Loading Demo地址https://github.com/guangqiang-liu/react-native-toastAndLoading Demo使用使用到的三方组件
注意
Toast组件toast组件这里作者分类8种不同的使用场景,目前能想到的就这多场景了,后面同学们有其他场景,可以自行添加即可,Toast组件中使用到的Icon图标,同学们也可以自行修改
Loading组件Loading组件最常用的使用场景就是网络请求时,数据还没有请求回来之前,页面最上层显示一个正在加载的loading框,一来能够防止用户在网络请求时又做其他的操作,二来可以给用户一个更好的体验,不至于页面空白,显得突兀
这里作者建议使用redux来控制Loading的显示与隐藏,这样不用在每一个需要网络请求的页面都手动去调用显示与隐藏,更高端的Loading使用技巧可以参照作者的React Native开发项目:OneM Toast核心源码const Toast = {
toast: null,show: msg => {
this.toast = RootToast.show(msg,{
position: 0,duration: 1500
})
},showLong: msg => {
this.toast = RootToast.show(msg,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,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,}) 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,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() } } }
更多文章
小伙伴们扫下方二维码加入RN技术交流QQ群(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |