V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
lbfeng
V2EX  ›  问与答

React native redux stateToProps 影响多个页面

  •  
  •   lbfeng · 2017-12-23 06:22:49 +08:00 · 1813 次点击
    这是一个创建于 2316 天前的主题,其中的信息可能已经有所发展或是发生改变。

    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 条附言  ·  2017-12-23 11:38:07 +08:00
    redux state 中有一个值会被两个页面用到,映射到各自的 props 中 this.props.islogged. 在 login 页面登陆成功或者在 signup 注册成功(自动登陆)可以在

    componentWillReceiveProps(nextProps) {
    if (!nextProps.islogged) {
    ....
    }
    }
    跳转到其他页。

    我的问题是无论是登陆成功还是注册成功,两个页面的 componentWillReceiveProps 都会被触发。怎么在能避免这种情况。
    第 2 条附言  ·  2017-12-24 01:39:51 +08:00
    解决了。问题出在 react-native-router-flux。从 login 到 signup,react-native-router-flux 的 stack 里还保存了 login 页且并没有被 umcount,所以当 state 变化时 login 会跳出来,如果把 login 移除的话问题就没了。
    8 条回复    2017-12-23 13:16:12 +08:00
    lightening
        1
    lightening  
       2017-12-23 08:04:10 +08:00
    完全没看懂你在说什么
    NonClockworkChen
        2
    NonClockworkChen  
       2017-12-23 09:10:05 +08:00
    Scene 1 为什么会又跳出来,这不是 react-navigation 控制的吗,和 redux 应该没关系吧.
    lbfeng
        3
    lbfeng  
    OP
       2017-12-23 09:18:30 +08:00
    好像不太好形容。贴个图

    https://media.giphy.com/media/xULW8pqdahzUKqBBC0/giphy.gif

    login 就是 Scene 1,signup 就是 Scene 2. signup 成功后,state.islogged 就是 true,但在跳到补全资料那页时会先跳回 login 页。
    lbfeng
        4
    lbfeng  
    OP
       2017-12-23 09:19:12 +08:00
    @NonClockworkChen 没用 react-navigation
    lbfeng
        5
    lbfeng  
    OP
       2017-12-23 11:18:35 +08:00
    signup 完成后 login 里的 componentWillReceiveProps 也被触发了一次。
    lbfeng
        6
    lbfeng  
    OP
       2017-12-23 11:22:42 +08:00
    在 login 里把 stateToProps islogged: state.islogged 去掉的话问题就消失了。
    Mikewu
        7
    Mikewu  
       2017-12-23 12:46:08 +08:00 via Android
    上个变量开关判断后再执行,在页面 1 跳转到下一个页面 2 前先改变变量开关,回来时再 onfresh。
    或者你在判断 this.props 与 nextProps 的 islogged 同时,增减个条件:前后 props 中 routeName 未发生变化就行了。
    wd
        8
    wd  
       2017-12-23 13:16:12 +08:00 via iPhone
    就是这样的啊 因为你的两个页面的 props 依赖同一个 state 那就是同时变的 不过你说的没明白…… 按说 login 和 register 不应该依赖 isloigin 啊 每次访问这页面不应该都不管是不是登陆吗?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   3993 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 33ms · UTC 05:16 · PVG 13:16 · LAX 22:16 · JFK 01:16
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.