无法读取未定义的属性“长度”[reactjs]
2016-09-25
5193
我正在尝试使用 reactjs 计算剩余字符。我已经定义了与状态对话并传递给子组件的函数。在子组件中,我收到错误 Uncaught TypeError: Cannot read property 'length' of undefined 。
app.js
export default class App extends Component {
constructor(props){
super(props);
this.state = {max_char:32};
this.handleChange = this.handleChange.bind(this);
}
handleChange(charLength){
console.log('charLength');
this.setState({
max_char:32 - charLength.length
});
console.log(this.state.max_char);
}
render() {
return (
<div>
<Layout fixedHeader>
<Content>
<div className="page-content">
<DeviceEventList />
<DeviceDialog onChange={this.handleChange} />
</div>
<div className="empty-space">
</div>
</Content>
</Layout>
</div>
);
}
}
device-dialog.js
class DeviceDialog extends Component {
constructor(props) {
super(props);
console.log('this.props',this.props.onChange);
}
handleInputChange(event){
console.log(event.target.value);
let name = event.target.value;
this.props.onChange(name);
}
renderOwnADevice(){
console.log('open',this.props.active_device_event.open);
return(
<div className="device-action">
<Dialog open={this.props.active_device_event.open} onCancel={this.props.CancelDeviceEvent}>
<DialogContent>
<Textfield
onChange={()=> {this.handleInputChange(event)}}
pattern="-?[0-9]*(\.[0-9]+)?"
error="Input is not a number!"
label="Device Serial Number"
floatingLabel
/>
<span style={{ float:'right'}}>character</span>
</DialogContent>
</Dialog>
</div>
)
}
render() {
if ( !this.props.active_device_event){
return <h5 style={{ textAlign:'center' }}>Click icon based on your work</h5>;
}
let icon_name = this.props.active_device_event.icon_name;
if( icon_name == 'devices_other'){
return (<div>Device Other</div>);
}
if( icon_name == 'add_circle_outline'){
return (this.renderOwnADevice());
}
}
}
2个回答
我猜想
onChange={()=> {this.handleInputChange(event)} 应为
onChange={(event) => {this.handleInputChange(event)} 。现在您传递的事件变量未定义。
另外:最好在构造函数中绑定处理程序,就像在
app.js
中所做的那样,而不是在渲染中使用匿名函数包装器。
pleunv
2016-09-25
event
从未在此行中定义:
onChange={()=> {this.handleInputChange(event)}>
。因此,您的
handleChange
函数接收的是
undefined
值,而不是字符串。
<Textfield
onChange={this.handleInputChange}
pattern="-?[0-9]*(\.[0-9]+)?"
error="Input is not a number!"
label="Device Serial Number"
floatingLabel
/>
您的
this.handleInputChange
现在将正确传递事件参数。
alecrobins
2016-09-25