【发布时间】:2018-05-09 12:00:53
【问题描述】:
您好,我有以下反应组件。
import React from 'react';
import PropTypes from 'prop-types';
import classNames from 'classnames';
const propTypes = {
/*
* Used to extend default object classes
*/
classes : PropTypes.object,
/*
* Click event handler
*/
onClick : PropTypes.func,
/*
* Delete event handler
*/
onRequestDelete : PropTypes.func,
/*
* This property will contain label text
*/
label : PropTypes.string
}
class Chip extends React.Component{
constructor(props){
super(props);
this.onClick = this.onClick.bind(this);
}
onClick(e) {
if (this.props.disabled) {
e.preventDefault();
return;
}
if (this.props.onClick) {
this.props.onClick(e);
}
}
handleDeleteIconClick(e){
e.stopPropagation();
if (this.props.onRequestDelete) {
this.props.onRequestDelete(event);
}
};
render(){
let defaultClasses = 'chips chips-rounded';
const {
classes,
onClick,
label,
onRequestDelete,
} = this.props;
return (
<div
className={classNames(classes, defaultClasses)}
onClick={onClick}
>
<span className={classes}>{label}</span>
{onRequestDelete ? (<div className="deleteIcon" onClick={ this.handleDeleteIconClick } />) : ''}
</div>
)
}
}
Chip.PropTypes = propTypes;
export default Chip
当我运行组件并触发handleDeleteIconClick 事件时,我收到以下错误。我在这里做错了什么。
Uncaught TypeError: Cannot read property 'props' of undefined
at handleDeleteIconClick (1.a0d91201f90f20151e22.hot-update.js:86)
at HTMLUnknownElement.boundFunc (main.bundle.js:8934)
at Object.ReactErrorUtils.invokeGuardedCallback (main.bundle.js:8940)
at executeDispatch (main.bundle.js:8725)
at Object.executeDispatchesInOrder (main.bundle.js:8748)
at executeDispatchesAndRelease (main.bundle.js:5786)
at executeDispatchesAndReleaseTopLevel (main.bundle.js:5797)
at Array.forEach (<anonymous>)
at forEachAccumulated (main.bundle.js:13425)
at Object.processEventQueue (main.bundle.js:5997)
【问题讨论】:
-
你在绑定
handleDeleteIconClick吗? -
是的,我将它绑定到 return 语句中的
deleteIcon元素。 -
在你绑定的构造函数中
this.onClick = this.onClick.bind(this);在代码中的任何地方都看不到habdleDeleteonClick -
当我添加绑定代码时,它会抛出一个
ReferenceError说handleDeleteIconClick没有定义。 -
我假设您将其绑定在构造函数中,例如
this.handleDeleteonClick = this.handleDeleteonClick.bind(this);
标签: javascript reactjs components