中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

react拖拽排序組件怎么使用

小億
112
2024-02-01 11:50:59
欄目: 編程語言

要使用React拖拽排序組件,首先需要安裝相關的庫。最常用的庫是react-dndreact-dnd-html5-backend

  1. 首先,在你的項目中安裝這兩個庫:
npm install react-dnd react-dnd-html5-backend
  1. 創建一個可拖拽的組件。你可以使用react-dnd提供的DragSourceDropTarget高階組件來實現拖拽功能。
import { DragSource, DropTarget } from "react-dnd";

const ItemTypes = {
  CARD: "card"
};

// 創建一個DragSource
const cardSource = {
  beginDrag(props) {
    return {
      id: props.id,
      index: props.index
    };
  }
};

const collectDragSource = (connect, monitor) => {
  return {
    connectDragSource: connect.dragSource(),
    isDragging: monitor.isDragging()
  };
};

// 創建一個DropTarget
const cardTarget = {
  drop(props, monitor) {
    const dragIndex = monitor.getItem().index;
    const hoverIndex = props.index;

    // 在這里可以調用一個回調函數來更新排序
    props.onMove(dragIndex, hoverIndex);
  }
};

const collectDropTarget = (connect, monitor) => {
  return {
    connectDropTarget: connect.dropTarget()
  };
};

// 最終的可拖拽組件
const DraggableCard = ({ text, isDragging, connectDragSource, connectDropTarget }) => {
  return connectDragSource(
    connectDropTarget(
      <div style={{ opacity: isDragging ? 0.5 : 1 }}>
        {text}
      </div>
    )
  );
};

export default DragSource(ItemTypes.CARD, cardSource, collectDragSource)(
  DropTarget(ItemTypes.CARD, cardTarget, collectDropTarget)(DraggableCard)
);
  1. 創建一個容器組件,用來渲染拖拽排序的列表。
import { useState } from "react";
import update from "immutability-helper";
import DraggableCard from "./DraggableCard";

const SortableList = () => {
  const [cards, setCards] = useState([
    { id: 1, text: "Card 1" },
    { id: 2, text: "Card 2" },
    { id: 3, text: "Card 3" }
  ]);

  const handleMoveCard = (dragIndex, hoverIndex) => {
    const dragCard = cards[dragIndex];

    setCards(
      update(cards, {
        $splice: [
          [dragIndex, 1],
          [hoverIndex, 0, dragCard]
        ]
      })
    );
  };

  return (
    <div>
      {cards.map((card, index) => (
        <DraggableCard
          key={card.id}
          id={card.id}
          index={index}
          text={card.text}
          onMove={handleMoveCard}
        />
      ))}
    </div>
  );
};

export default SortableList;
  1. 最后,在你的應用中使用SortableList組件。
import SortableList from "./SortableList";

const App = () => {
  return (
    <div>
      <h1>Sortable List</h1>
      <SortableList />
    </div>
  );
};

export default App;

現在,你就可以在應用中使用拖拽排序組件了。當你拖拽一個卡片并放置到另一個位置時,列表將會重新排序。

0
平湖市| 会泽县| 玉环县| 元谋县| 鄂伦春自治旗| 崇礼县| 张家港市| 康平县| 沈阳市| 德昌县| 漳浦县| 永宁县| 舞钢市| 西青区| 婺源县| 玛纳斯县| 茶陵县| 松原市| 资源县| 乐东| 石家庄市| 乐昌市| 永德县| 武乡县| 榆社县| 长子县| 元氏县| 张北县| 垣曲县| 宕昌县| 吴忠市| 九龙县| 屯昌县| 耿马| 正安县| 娄底市| 台州市| 阿城市| 嘉黎县| 嘉兴市| 林周县|