простой список в реакции красивый и не работает - PullRequest
1 голос
/ 21 марта 2019

Я прошел официальный курс по яйцу (https://egghead.io/lessons/react-reorder-a-list-with-react-beautiful-dnd и образец рабочего кода: https://codesandbox.io/s/52p60qqlpp) и написал это:

https://codesandbox.io/s/00k3rwq3qn

Тем не менее, на самом деле это не перетаскивание. Я просмотрел несколько примеров, и я не могу определить проблему в своем коде. Я был бы очень признателен, если бы кто-то дал отзыв о моей ошибке.

Спасибо

1 Ответ

1 голос
/ 22 марта 2019

Я не думаю, что использование встроенных стилей работает так хорошо с Draggable в react-beautiful-dnd. Если вы хотите применить стиль к компоненту Task, вы должны использовать styled-components, этот пример показывает, что он работает, если вы удалите конфигурацию встроенного стиля https://codesandbox.io/s/6lq0854m6r.

Скорее используйте styleled-компоненты

import React from "react";
import styled from "styled-components";
import { Draggable } from "react-beautiful-dnd";

const Container = styled.div`
  margin: 10px;
  border: 1px solid black;
`;

export default class Task extends React.Component {
  render() {
    return (
      <Draggable draggableId={this.props.task.id} index={this.props.index}>
        {(provided, snapshot) => (
          <Container
            {...provided.draggableProps}
            {...provided.dragHandleProps}
            ref={provided.innerRef}
          >
            {this.props.task.content}
          </Container>
        )}
      </Draggable>
    );
  }
}

EDIT: Кажется, вы можете применить встроенные стили к перетаскиваемому элементу, но тогда вам следует расширить DraggableProps.styles внутри дочерней функции компонента Draggable, см. здесь .

{(provided, snapshot) => (
    const style = {
        margin: "10px",
        border: "1px solid black",
        ...provided.draggableProps.style,
    };
    return <div
        {...provided.draggableProps}
        {...provided.dragHandleProps}
        ref={provided.innerRef}
        style={style}
        >
        {this.props.task.content}
    </div>
)}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...