Scene 1:
stateToProps islogged: state.islogged
Scene 2:
stateToProps islogged: state.islogged
用 react-native-router-flux 中的 Actions 从 1 转到 2,2 中触发 action(是个 fetch 操作),islogged 值改变,在 componentWillReceiveProps 做个判断,这时 1 又跳出来了???,判断里的内容继续。有什么办法能不让 1 跳出来吗?
1
lightening 2017-12-23 08:04:10 +08:00
完全没看懂你在说什么
|
2
NonClockworkChen 2017-12-23 09:10:05 +08:00
Scene 1 为什么会又跳出来,这不是 react-navigation 控制的吗,和 redux 应该没关系吧.
|
3
lbfeng OP 好像不太好形容。贴个图
https://media.giphy.com/media/xULW8pqdahzUKqBBC0/giphy.gif login 就是 Scene 1,signup 就是 Scene 2. signup 成功后,state.islogged 就是 true,但在跳到补全资料那页时会先跳回 login 页。 |
4
lbfeng OP @NonClockworkChen 没用 react-navigation
|
5
lbfeng OP signup 完成后 login 里的 componentWillReceiveProps 也被触发了一次。
|
6
lbfeng OP 在 login 里把 stateToProps islogged: state.islogged 去掉的话问题就消失了。
|
7
Mikewu 2017-12-23 12:46:08 +08:00 via Android
上个变量开关判断后再执行,在页面 1 跳转到下一个页面 2 前先改变变量开关,回来时再 onfresh。
或者你在判断 this.props 与 nextProps 的 islogged 同时,增减个条件:前后 props 中 routeName 未发生变化就行了。 |
8
wd 2017-12-23 13:16:12 +08:00 via iPhone
就是这样的啊 因为你的两个页面的 props 依赖同一个 state 那就是同时变的 不过你说的没明白…… 按说 login 和 register 不应该依赖 isloigin 啊 每次访问这页面不应该都不管是不是登陆吗?
|