首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >react-native-router-flux: onLeft场景

react-native-router-flux: onLeft场景
EN

Stack Overflow用户
提问于 2017-03-30 20:04:06
回答 1查看 617关注 0票数 0

我正在尝试为场景employeeEdit场景添加重置,当用户从场景返回时,如果用户不希望对当前选定的员工进行更改,他们将能够返回到员工列表,并且当使用类型:‘onLeft’进行添加时,这些字段将被清空,就好像我们要保存更改一样。

在这种情况下,onLeft似乎不起作用,因为函数实际上并没有被执行。

代码语言:javascript
复制
<Router sceneStyle={{ paddingTop: 65 }}>
    <Scene key="auth">
        <Scene key="login" component={LoginForm} title="Please Login" initial />
    </Scene>

    <Scene key="main">
        <Scene 
            onRight={() => Actions.employeeCreate()}
            rightTitle="Add"
            key="employeeList" 
            component={EmployeeList} 
            title="Employees" 
            initial
        />
        <Scene
            key="employeeCreate" 
            component={EmployeeCreate} 
            title="Create Employee" 
        />
        <Scene
            onLeft={() => Actions.employeeList({ type: 'reset' })}
            key="employeeEdit" 
            component={EmployeeEdit} 
            title="Edit Employee" 
        />                
    </Scene>
</Router>
EN

回答 1

Stack Overflow用户

发布于 2017-04-03 20:07:59

一种更长的方法。

使用componentWillUnmount时,这在离开组件(即EmployeeEdit )时非常有效

代码语言:javascript
复制
componentWillUnmount () {
    this.props.employeeInitial();
}

然后,这可以调用gigInitial的一个属性;具有一个将返回类型为“EMPLOYEE_INITIAL”的调度的操作。

代码语言:javascript
复制
export const employeeInitial = () => {
    return (dispatch) => {
        dispatch({ type: EMPLOYEE_INITIAL });
    };
};

,然后在EmployeeFormReducer中返回INITIAL_STATE。

代码语言:javascript
复制
case EMPLOYEE_INITIAL:
    return INITIAL_STATE;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43117362

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档