React Downshift добавляет URL-ссылки в раскрывающийся список

Я хочу добавить URL-ссылки в приведенный ниже скрипт с помощью Downshift

У меня есть в книжном состоянии атрибут имени и ссылки. Имена книг отлично отображаются в раскрывающемся списке, но мне интересно, как мне лучше всего использовать ссылки для каждого раскрывающегося элемента. Я бы хотел, чтобы список раскрылся, и, например, щелкните книгу о Гарри Поттере, и она будет ссылаться на страницу о Гарри Поттере.

Вот код, который я использую:

CodeSandbox:https://codesandbox.io/s/dropdown-with-downshift-1c978?fontsize=14

import React, { Component } from "react";
import ReactDOM from "react-dom";
import Downshift from "downshift";

import "./styles.css";

class DownshiftThree extends Component {
  constructor(props) {
    super(props);
    this.books = [
      { name: "Harry Potter", link: "/harry-potter" },
      { name: "Net Moves", link: "/net-moves" },
      { name: "Half of a yellow sun", link: "/yellow-sun" },
      { name: "The Da Vinci Code", link: "/da-vinci-code" },
      { name: "Born a crime", link: "/born-a-crime" }
    ];

    this.state = {
      selectedBook: ""
    };

    this.onChange = this.onChange.bind(this);
  }

  onChange(selectedBook) {
    this.setState({ selectedBook: selectedBook.name });
  }

  render() {
    return (
      <Downshift
        onChange={this.onChange}
        selectedItem={this.state.selectedBook}
        itemToString={books => (books ? books.name : "")}
      >
        {({
          isOpen,
          getToggleButtonProps,
          getItemProps,
          highlightedIndex,
          selectedItem: dsSelectedItem,
          getLabelProps
        }) => (
          <div>
            <label
              style={{ marginTop: "1rem", display: "block" }}
              {...getLabelProps()}
            >
              Select your favourite book
            </label>{" "}
            <br />
            <button className="dropdown-button" {...getToggleButtonProps()}>
              {this.state.selectedBook !== ""
                ? this.state.selectedBook
                : "Select a book ..."}
            </button>
            <div style={{ position: "relative" }}>
              {isOpen ? (
                <div className="downshift-dropdown">
                  {this.books.map((item, index) => (
                    <div
                      className="dropdown-item"
                      {...getItemProps({ key: index, index, item })}
                      style={{
                        backgroundColor:
                          highlightedIndex === index ? "lightgray" : "white",
                        fontWeight: dsSelectedItem === item ? "bold" : "normal"
                      }}
                    >
                      <a href="{item.link}">{item.name}</a>
                    </div>
                  ))}
                </div>
              ) : null}
            </div>
          </div>
        )}
      </Downshift>
    );
  }
}

const rootElement = document.getElementById("root");
ReactDOM.render(<DownshiftThree />, rootElement);

0 ответов

Другие вопросы по тегам