1

我正在使用react-select在我的反应应用程序中定义一个选择输入控件。这就是我使用组件的方式:

<Select
   onChange={function(e) {console.log(e)}}
   options={[
      {value: "sf", label: "San Francisco"},
      {value: "nyc", label: "New York City"}
   ]}
></Select>

在选择任何选项之前,我看到一个Select...占位符作为输入值。选择选项后这不会改变:输入值不会改变,Select...占位符似乎是选定的“选项”。

我使用组件的方式有问题吗?

4

1 回答 1

5

在变量中定义Select值,函数将返回一个,将其分配给状态变量,它将起作用,检查此代码:statelogChangeobjectvalueobject

class App extends React.Component{

  constructor(){
     super();
     this.state = {value: ''}
  }
   
  logChange(val) {
    console.log("Selected: " + val.value);
    this.setState({value: val.value});
  }

  render(){
    var options = [
       {value: 'one', label: 'One' },
       {value: 'two', label: 'Two' } 
    ];
    return(
      
      <Select
          name="form-field-name"
          value={this.state.value}
          options={options}
          onChange={this.logChange.bind(this)}
      />
      
    )
  }
}

ReactDOM.render(<App/>, document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<script src="https://unpkg.com/classnames/index.js"></script>
<script src="https://unpkg.com/react-input-autosize/dist/react-input-autosize.js"></script>
<script src="https://unpkg.com/react-select/dist/react-select.js"></script>

<link rel="stylesheet" href="https://unpkg.com/react-select/dist/react-select.css">

<div id='app'/>

于 2017-03-09T08:52:02.700 回答