为了账号安全,请及时绑定邮箱和手机立即绑定

TypeError:this.props.onDelete 不是函数

TypeError:this.props.onDelete 不是函数

白板的微信 2022-05-22 11:25:50
我正在使用 react.js 开发事件 crud 应用程序,但出现此错误:TypeError:this.props.onDelete 不是函数这是用户界面:这是我点击删除时的错误:当我点击编辑时,我也会遇到同样的错误。这是代码:import React, { Component } from "react";class Event extends Component {  onDelete = () => {    // console.log('event ', this.props.event.id);    this.props.onDelete(this.props.id);  };  onEdit = () => {    // console.log('event ', this.props.event.id);    this.props.onEdit(this.props);  };  render() {    const { id, eventname, eventdescription } = this.props.event;    return (      <tr>        <td>{id}</td>        <td>{eventname}</td>        <td>{eventdescription}</td>        <td>          <button onClick={this.onEdit}>Edit</button>          <button onClick={this.onDelete}>Delete</button>        </td>      </tr>    );  }}export default Event;
查看完整描述

2 回答

?
千巷猫影

TA贡献1829条经验 获得超7个赞

<Event key={event.id} event={event} onDelete={this.onDelete} onEdit={this.onEdit} />

onDelete 未在 DisplayEvent 组件中声明


查看完整回答
反对 回复 2022-05-22
?
幕布斯7119047

TA贡献1794条经验 获得超8个赞

Event组件正在组件内部使用DisplayEvents。 DisplayEvents正在将道具传递onDeleteEvent.

查看您的代码,onDeleteprop 的值是this.onDelete您尚未定义的值,DisplayEvents这意味着 undefined 正在传递给子组件(类似这样的 : <Event onDelete={undefined} >)。contructor您可以通过安慰组件中的道具来检查这一点Event

您需要在父级中定义您的函数,然后将其作为道具传递给子级。

您可以查看 sanbox链接以供参考


查看完整回答
反对 回复 2022-05-22
  • 2 回答
  • 0 关注
  • 157 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号