dispatch 不是函数 TypeError

cid*_*cid 3 javascript reactjs redux redux-thunk react-redux

我是 react-redux 的新手,我正在使用 react-thunk 中间件。每当我尝试运行我的动作创建者(通过按下我的按钮)时,我都会收到错误“未捕获的类型错误:调度不是函数”。有谁知道这是怎么回事?

源代码/操作/index.js

function editUserName (newUserName) {
    return {
        type: 'CHANGE_USER_NAME',
        newUserName: newUserName
    }
}

export function editUserNameDelegate () {
    return function (dispatch, getState) {
        return dispatch(editUserName("thunkUser"))
    }
}
Run Code Online (Sandbox Code Playgroud)

src/容器/admin.js

import { editUserNameDelegate } from '../actions/index'
...
<input type="button" onClick={ editUserNameDelegate() } value="edit UserName" />
Run Code Online (Sandbox Code Playgroud)

mar*_*son 5

您正在 中执行editUserNameDelegate函数render,而不是将其作为onClick处理程序传递。你想要onClick={editUserNameDelegate}

此外,如果您是这样编写的,则需要确保该函数在调用时绑定到 dispatch。你可以这样做:

export default connect(null, {editUserNameDelegate})(MyComponent)

然后传入onClick={this.props.editUserNameDelegate}你的渲染函数。