编程语言
首页 > 编程语言> > javascript – React ES6:使用语义UI在下拉列表中获取所选值

javascript – React ES6:使用语义UI在下拉列表中获取所选值

作者:互联网

鉴于以下数据,如何获取鸟的名称并将其推送(使用添加按钮)到新数组以显示在另一个div中(使用react es6)?所以基本上我希望用户从语义下拉列表中单击一个鸟并将其显示在不同的div中,如下所示.这可能很简单,但是当我使用语义元素时,我似乎无法找到它的方法.我需要使用onChange吗?

我需要在我正在导出的类(反应)中执行此操作(只是没有显示类/构造函数/状态定义)

<div>
    <p>How can i display 'Bird_Name' here?<p>
</div>
addClick = () => {
        
}

const {
  Button,
  Container,
  Divider,
  Dropdown,
  Header,
  Message,
  Segment,
} = semanticUIReact

const birds = [
            {
                "value": "001",
                "Bird_Name": "Eurasian Collared-Dove"
            },
            {
                "value": "002",
                "Bird_Name": "Bald Eagle"
            },
            {
                "value": "003",
                "Bird_Name": "Cooper's Hawk"
            },
        ];

const options = birds.map(({ ID, Bird_Name }) => ({ value: ID, text: Bird_Name }))

const App = () => (
  <Container>
    <Divider hidden />
    <Header as='h1'>Semantic-UI-React</Header>
    <Dropdown 
      placeholder='Select...' 
      selection
      search
      options={options}
      renderLabel={({ Bird_Name }) => 1}
      />
      <button className="ui primary button add" onClick={this.addClick}>Add</button>
  </Container>
)

// ----------------------------------------
// Render to DOM
// ----------------------------------------
const mountNode = document.createElement('div')
document.body.appendChild(mountNode)

ReactDOM.render(<App />, mountNode)

解决方法:

所以,你基本上想要的是将显示的onChange函数

 <Dropdown 
  placeholder='Select...' 
  selection
  search
  options={options}
  renderLabel={({ Bird_Name }) => 1}
  onChange={this.getBird}
  />

并创建一个getBird函数

getBird = (event, {value}) => {
    console.log(value);
    let bird_name = e.target.textContent;
    console.log(bird_name);
}

getBird函数中的value和text变量基本上是下拉列表中所选鸟的值和bird_name.

标签:javascript,reactjs,semantic-ui
来源: https://codeday.me/bug/20190607/1195173.html