为了账号安全,请及时绑定邮箱和手机立即绑定

在<input>中获取<option>属性

在<input>中获取<option>属性

繁星coding 2022-06-09 17:19:15
我有返回给我选项的功能:const codesList = () => {  return businessCodes.map((code, index) => {    return <option key={code.BusinessCode}>{code.IndustryName}</option>;  });};然后我有取值的数据列表和输入字段:      <input            type="text"            className="filter-select-form-control"            placeholder="Enter Business Code"            id="business-code"            list="code-dataList"            autoComplete="off"          ></input>        </div>        {/* DATALISTS CODES*/}        <datalist id="code-dataList">          {RightFilterFunction.codesList()}        </datalist>之后在获取输入字段值的函数中,出现以下情况:const businessCode = document.getElementById("business-code").value;用这部分代码给businessCode 分配了确切的code.IndustryName。我想知道如何访问选项 key={code.BusinessCode} 的这个关键属性。我想为businessCode分配code.BusinessCode,但datalist保留code.IndustryName。JSON(businessCodes 数组)的一部分,您将知道为什么我更喜欢将 IndustryName 可视化并将 BusinessCode 发送到端点:{    BusinessCode: 111,    IndustryName: "Crop Production"  },  {    BusinessCode: 112,    IndustryName: "Animal Production and Aquaculture"  },  {    BusinessCode: 113,    IndustryName: "Forestry and Logging"  }
查看完整描述

2 回答

?
潇潇雨雨

TA贡献1833条经验 获得超4个赞

您可以使用state来跟踪代码数组中的选定对象,因此您同时拥有BusinessCode和IndustryName


尽可能避免在 React 中使用 jQuery。检查下面的代码:


const businessCodes = [{

    BusinessCode: 111,

    IndustryName: "Crop Production"

  },

  {

    BusinessCode: 112,

    IndustryName: "Animal Production and Aquaculture"

  },

  {

    BusinessCode: 113,

    IndustryName: "Forestry and Logging"

  }];

  

const codesList = () => {

  return businessCodes.map((code, index) => {

    return <option key={code.BusinessCode}>{code.IndustryName}</option>;

  });

};


class App extends React.Component {

   constructor(props) {

    super(props);

    this.state = {selectedOption: {}};

    this.handleChange = this.handleChange.bind(this);

  }


  handleChange(event) {

    let selectedOption;

    let filtered = businessCodes.filter(item => item["IndustryName"] === event.target.value)

    

    if(filtered.length) selectedOption = filtered[0]

    else selectedOption = {}

    

    this.setState({selectedOption}, function(){

      if(Object.keys(this.state.selectedOption).length)

        console.log(this.state.selectedOption)

    });

  }

  

  render() {

    return (

      <div>

        <input

            type="text"

            placeholder="Enter Business Code"

            list="code-dataList"

            autoComplete="off"

            value={this.state.value} 

            onChange={this.handleChange}

          />

        {/* DATALISTS CODES*/}

        <datalist id="code-dataList">

          {codesList()}

        </datalist>

      </div>

    );

  }

}


// Render it

ReactDOM.render(

  <App />,

  document.getElementById("react")

);

<div id="react"></div>

<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>


查看完整回答
反对 回复 2022-06-09
?
翻阅古今

TA贡献1780条经验 获得超5个赞

实际上,您错误地使用了它,并且永远不要尝试在 React 中访问像 getElementById("business-code") 这样的 DOM。这是一种不好的做法,并且总是通过 onChange 事件获得价值。


使用值而不是键,问题将得到解决。


{this.state.businessCodes.map((code, index) => (

            <option key={index} value={code.BusinessCode}>

              {code.IndustryName}

            </option>

          ))}


完整代码它是如何在 React 上工作的。


import React, { Component } from "react";


class App extends Component {

  state = {

    businessCodes: [

      {

        BusinessCode: 111,

        IndustryName: "Crop Production"

      },

      {

        BusinessCode: 112,

        IndustryName: "Animal Production and Aquaculture"

      },

      {

        BusinessCode: 113,

        IndustryName: "Forestry and Logging"

      }

    ]

  };


  render() {

    return (

      <div>

        <input

          type="text"

          name="code"

          className="filter-select-form-control"

          placeholder="Enter Business Code"

          id="business-code"

          list="code-dataList"

          autoComplete="off"

        />

        <datalist id="code-dataList">

          {this.state.businessCodes.map((code, index) => (

            <option key={index} value={code.BusinessCode}>

              {code.IndustryName}

            </option>

          ))}

        </datalist>

      </div>

    );

  }

}


export default App;


查看完整回答
反对 回复 2022-06-09
  • 2 回答
  • 0 关注
  • 288 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信