开发者问题收集

无法读取未定义的属性“长度”[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