材质UI反应自动完成设置不同的标签和不同的值

时间:2020-05-01 15:47:01

标签: javascript reactjs autocomplete material-ui

我们可以在https://material-ui.com/components/autocomplete/

看到示例

我想将选项标签和值设置为不同。

就像这里的示例

    const defaultProps = {
       options: top5Films,
       getOptionLabel: (option) => option.title,
    };

    <Autocomplete
      {...defaultProps}
      id="auto-complete"
      value={value}
      onChange={(event, newValue) => {
        setValue(newValue);
      }}
      autoComplete
      includeInputInList
      renderInput={(params) => <TextField {...params} label="clearOnEscape" margin="normal"/>}
    />
    const top5Films= [
    { title: 'The Shawshank Redemption', year: 1994 },
    { title: 'The Godfather', year: 1972 },
    { title: 'The Godfather: Part II', year: 1974 },
    { title: 'The Dark Knight', year: 2008 },
    { title: '12 Angry Men', year: 1957 }
    ]

但是我有类似的数据:

const top5Films= [
    { id: 1, title: 'The Shawshank Redemption', year: 1994 },
    { id: 2, title: 'The Godfather', year: 1972 },
    { id: 3, title: 'The Godfather: Part II', year: 1974 },
    { id: 4, title: 'The Dark Knight', year: 2008 },
    { id: 5, title: '12 Angry Men', year: 1957 }
    ]

我想将id设置为值,并将标题显示为标签。

3 个答案:

答案 0 :(得分:1)

看起来对象已分配给该值。

因此将id设置为value会使选项崩溃。

我以下列方式使用对象的ID进行进一步的操作。

/* eslint-disable no-use-before-define */
import React from "react";
import TextField from "@material-ui/core/TextField";
import Autocomplete from "@material-ui/lab/Autocomplete";

export default function Playground() {
  const [value, setValue] = React.useState(null);
  const [id, setId] = React.useState(null);
  const [title, setTitle] = React.useState(null);

  return (
    <div>
      <div>{`value: ${value}`}</div>
      <div>{`id: ${id}`}</div>
      <div>{`title: ${title}`}</div>

      <br />
      <div style={{ width: 300 }}>
        <Autocomplete
          options={top5Films}
          getOptionLabel={option => option.title}
          id="movies"
          value={value}
          onChange={(event, newValue) => {
            console.log(newValue);
            if (newValue) {
              setValue(newValue);
              setId(newValue.id);
              setTitle(newValue.title);
            }
          }}
          renderInput={params => (
            <TextField {...params} label="Movies" margin="normal" />
          )}
        />
      </div>
    </div>
  );
}

// Top 5 films as rated by IMDb users. http://www.imdb.com/chart/top
const top5Films = [
  { id: 1, title: "The Shawshank Redemption", year: 1994 },
  { id: 2, title: "The Godfather", year: 1972 },
  { id: 3, title: "The Godfather: Part II", year: 1974 },
  { id: 4, title: "The Dark Knight", year: 2008 },
  { id: 5, title: "12 Angry Men", year: 1957 }
];

目前该方法有效,但始终欢迎最佳答案。

答案 1 :(得分:0)

我无法完全理解您的问题,但我想您希望getOptionLabel具有不同的显示选项,并且下拉列表中具有不同的显示。在这种情况下,您可以简单地使用Material UI提供的renderOption。在此处查看示例:https://codesandbox.io/s/94xlp?file=/demo.js

import React from "react";
import { TextField } from "@material-ui/core";
import { Autocomplete } from "@material-ui/lab";

  return (
   <Autocomplete
                            freeSolo
                            name=""
                            options={top5Films }
                            getOptionLabel={(option) => option.title} //Displays title only in input field
                            renderOption={(option) => (
                              <React.Fragment>
                                {option.title + "," + " " + option.year}  //Displays title + year in dropdown list
                              </React.Fragment>
                            )}
                            renderInput={params => (
                              <Field
                                component={FormikTextField}
                                {...params}
                                label=""
                                name=""
                              />
                            )}
                          />
  );
}

答案 2 :(得分:0)

试试这个,设置一个json值并使用inputValue的名称,输入值不变为什么不调用onChange函数

<Autocomplete
  options={machineList}
  inputValue={formValues.machine.name || ""} // from formik context in my case
  onChange={(e, value) => {
    setValues(
      "machine",
      value && value.id ? { id: value.id, name: value.name } : ""  //use json value
    );
  }}
  getOptionLabel={(option) => option.name}
  renderInput={(params) => (
    <InputField
      {...params}
      type="text"
      name={machine.name}
      label={machine.label}
      fullWidth
    />
  )}
/>;