传递整个选定的对象数据on Change

发布于 2025-02-13 01:40:18 字数 862 浏览 1 评论 0 原文

let arr=[{name:'trtr', ID:5}, {name:'FGF', ID:8},{name:'adaf', ID:4}, {name:'tyhrf', ID:7}]
<Select size="small"
                placeholder="Select..."
                allowClear
                showSearch
                onChange={(name) => this.filterGroupRecord(Group)}
                value={this.state.arrselected}
                dropdownMatchSelectWidth={false}
                style={{ width: 250, marginLeft: 8, marginRight: 8 }}
                filterOption={(input, option) =>
                  option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
                }>
                {arr && this.arr.map((dd) => dd.name && <Select.Option value={dd.name}>{dd.name}</Select.Option>)}

              </Select>

我想在Onchange中传递选定的名称和整个对象。但这只会得到名字。如何传递整个选定的对象数据?

let arr=[{name:'trtr', ID:5}, {name:'FGF', ID:8},{name:'adaf', ID:4}, {name:'tyhrf', ID:7}]
<Select size="small"
                placeholder="Select..."
                allowClear
                showSearch
                onChange={(name) => this.filterGroupRecord(Group)}
                value={this.state.arrselected}
                dropdownMatchSelectWidth={false}
                style={{ width: 250, marginLeft: 8, marginRight: 8 }}
                filterOption={(input, option) =>
                  option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
                }>
                {arr && this.arr.map((dd) => dd.name && <Select.Option value={dd.name}>{dd.name}</Select.Option>)}

              </Select>

I want to pass selected name and whole object in onchange. But it only getting name. How to pass whole selected object datas?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

情定在深秋 2025-02-20 01:40:18

您可以将ARR对象作为字符串值传递为选项值中的字符串值,您可以找到一个工作示例在这里

import React, { useState } from "react";
import "antd/dist/antd.css";
import { Select } from "antd";

let arr = [
  { name: "trtr", ID: 5 },
  { name: "FGF", ID: 8 },
  { name: "adaf", ID: 4 },
  { name: "tyhrf", ID: 7 }
];

const App = () => {
  const [arrselected, setArrSelected] = useState({});

  const filterGroupRecord = (data) => {
    console.log(JSON.parse(data));
    setArrSelected(data);
  };

  return (
    <Select
      size="small"
      placeholder="Select..."
      allowClear
      showSearch
      onChange={(data) => filterGroupRecord(data)}
      value={arrselected}
      dropdownMatchSelectWidth={false}
      style={{ width: 250, marginLeft: 8, marginRight: 8 }}
      filterOption={(input, option) =>
        option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
      }
    >
      {arr &&
        arr.map(
          (dd) =>
            dd.name && (
              <Select.Option value={JSON.stringify(dd)}>
                {dd.name}
              </Select.Option>
            )
        )}
    </Select>
  );
};

export default App;


you can pass arr object as a string value in the option value you can find a working example here

import React, { useState } from "react";
import "antd/dist/antd.css";
import { Select } from "antd";

let arr = [
  { name: "trtr", ID: 5 },
  { name: "FGF", ID: 8 },
  { name: "adaf", ID: 4 },
  { name: "tyhrf", ID: 7 }
];

const App = () => {
  const [arrselected, setArrSelected] = useState({});

  const filterGroupRecord = (data) => {
    console.log(JSON.parse(data));
    setArrSelected(data);
  };

  return (
    <Select
      size="small"
      placeholder="Select..."
      allowClear
      showSearch
      onChange={(data) => filterGroupRecord(data)}
      value={arrselected}
      dropdownMatchSelectWidth={false}
      style={{ width: 250, marginLeft: 8, marginRight: 8 }}
      filterOption={(input, option) =>
        option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
      }
    >
      {arr &&
        arr.map(
          (dd) =>
            dd.name && (
              <Select.Option value={JSON.stringify(dd)}>
                {dd.name}
              </Select.Option>
            )
        )}
    </Select>
  );
};

export default App;


浮华 2025-02-20 01:40:18

我希望这会有所帮助,您也可以在此链接

let arr=[{name:'trtr', ID:5}, {name:'FGF', ID:8},{name:'adaf', ID:4}, {name:'tyhrf', ID:7}]

<Select size="small"
    placeholder="Select..."
    allowClear
    showSearch
    onChange={(event) => this.filterGroupRecord(JSON.parse(event))}
    value={this.state.arrselected}
    dropdownMatchSelectWidth={false}
    style={{ width: 250, marginLeft: 8, marginRight: 8 }}
    filterOption={(input, option) =>
      option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
    }>
  {arr && this.arr.map((dd) => dd.name && <Select.Option value={JSON.stringify(dd)}>{dd.name}</Select.Option>)}

</Select>

I hope this would be helpful, also you can see the example on this link

let arr=[{name:'trtr', ID:5}, {name:'FGF', ID:8},{name:'adaf', ID:4}, {name:'tyhrf', ID:7}]

<Select size="small"
    placeholder="Select..."
    allowClear
    showSearch
    onChange={(event) => this.filterGroupRecord(JSON.parse(event))}
    value={this.state.arrselected}
    dropdownMatchSelectWidth={false}
    style={{ width: 250, marginLeft: 8, marginRight: 8 }}
    filterOption={(input, option) =>
      option.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
    }>
  {arr && this.arr.map((dd) => dd.name && <Select.Option value={JSON.stringify(dd)}>{dd.name}</Select.Option>)}

</Select>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文