单击按钮时从另一个组件调用函数时出错

IT技术 reactjs
2021-05-16 06:55:14

在我的 ReactJS 代码中,通过使用 refs,我在单击相应按钮时调用 View 组件内的 Action 组件的 addRecord 和 deleteRecord 函数。但我收到一个错误(在下面发布)。请告诉我的代码有什么问题?

错误:

Uncaught TypeError: Cannot read property 'deleteRecord' of undefined
    at new View (index.js:32602)
    at index.js:28264
...

视图.jsx

import React from 'react';
import Action from './Action.jsx';

class View extends React.Component {
    constructor() {
        super();

        this.refs.actionHandler.deleteRecord = this.refs.actionHandler.deleteRecord.bind(this);
        this.refs.actionHandler.addRecord = this.refs.actionHandler.addRecord.bind(this);
    };

    render() {
        return (
            <div className="container">
                <ul className="list-group">
                    {this.props.store.map((eachRecord) => (
                    <li className="list-group-item" key={eachRecord.id}>{eachRecord.name}
                    <button style={{float:'right'}} onClick={this.refs.actionHandler.deleteRecord(eachRecord)}>Delete</button></li>))}
                </ul>
                <input type="text" ref="inputElement"/>
                <button onClick={this.refs.actionHandler.addRecord(this.refs.inputElement)}>Add</button>
                <Action ref="actionHandler" store={this.props.store} updateStore={this.props.updateStore} />
            </div>
        );
    }
}

export default View;

动作.jsx

import React from 'react';
import Dispatcher from './Dispatcher.jsx';

let recordId=3;

class Action extends React.Component {
    render() {
        return (
            <div>
                <Dispatcher updateStore={this.props.updateStore} ref="dispatcher" />
            </div>
        );
    };

    addRecord(input) {
        const inputElement = input;
        const text = inputElement.value.trim();
        inputElement.value = '';
        inputElement.focus();

        ++recordId;
        var newRecord = {name: text, id: recordId};
        var newStore = this.props.store;
        newStore.push(newRecord);

        this.refs.dispatcher.dispatchChanges(newStore);
    };

    deleteRecord(record) {
        var newStore = this.props.store.filter(r => r !== record);
        this.refs.disptacher.dispatchChanges(newStore);
    }
}

export default Action;
1个回答

我正在查看您的代码,但看不到您传入的位置 deleteRecord

<Action ref="actionHandler" 
store={this.props.store} 
updateStore={this.props.updateStore} />