详解react native页面间传递数据的几种方式
1.利用react-native事件DeviceEventEmitter监听广播
应用场景:
-表单提交页面,A页面跳转到B页面选人,然后返回A页面,需要将B页面选择的数据传回A页面。
-多个多媒体来回切换播放,暂停后二次继续播放等问题。
代码如下:
A页面
componentDidMount(){
//利用DeviceEventEmitter监听concactAdd事件
this.subscription=DeviceEventEmitter.addListener('concactAdd',(dic)=>{//dic为触发事件回传回来的数据
//接收到update页发送的通知,后进行的操作内容
if(dic.approver_list){
this.setState((preState:Object)=>{
this.updateInputValue(preState.approver_list.concat(dic.approver_list),'approver_list');
return{approver_list:preState.approver_list.concat(dic.approver_list)};
});
}
if(dic.observer_list){
this.setState((preState:Object)=>{
this.updateInputValue(preState.observer_list.concat(dic.observer_list),'observer_list');
return{observer_list:preState.observer_list.concat(dic.observer_list)};
});
}
});
...
componentWillUnmount(){
this.subscription.remove();
}
B页面
//触发concactAdd事件广播
handleOk=(names:[])=>{
const{field}=this.props;
DeviceEventEmitter.emit('concactAdd',{[field]:names});
}
2.用react-navigation提供的路由之间
A页面
//定义路由跳转函数cb表示需要传递的回调函数
exportconstnavigateToLinkman=(cb:Function,type?:string,mul?:boolean):NavigateAction=>
NavigationActions.navigate({routeName:'Linkman',params:{cb,type,mul}});
//跳转选择人员页面
handleSelectUser=()=>{
Keyboard.dismiss();
this.props.actions.navigateToLinkman(this.selectedUser,'',true);
...
//选择人员后的回调函数
selectedUser=(selectUser:string[])=>{
this.setState((preState)=>{
constnewEmails=preState.emails.concat(selectUser);
constemails=[...newSet(newEmails)];
return{
emails,
};
});
}
B页面
handleToUser=()=>{
...
navigation.state.params.cb(user.email,group);
...
}
3.利用react-navigation提供的路由事件监听触发事件
在A页面路由失去焦点的时候触发该事件
componentDidMount(){
this.props.navigation.addListener('didBlur',(payload)=>{
if(this.modalView)this.modalView.close();
});
}
那么问题来了,为何不在页面卸载(componentWillunmount)的时候触发该事件?
如果不了解react-native和react-navigation,会很困惑,A页面卸载了,为什么还能接收到来自B页面的数据或者事件,原因是:react-navigation中,A页面跳转到B页面,A页面没有卸载,只是在它提供的路由栈中堆积,例如A跳转到B中,A页面不执行componentWillunmount,当每一个路由pop掉的时候才会执行componentWillunmount,卸载掉当前页面。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。