91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

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
清远市| 漳平市| 通州区| 宜兰市| 辽宁省| 涞源县| 开阳县| 沾益县| 顺义区| 康马县| 鲜城| 阿坝| 开封市| 深水埗区| 镇沅| 即墨市| 新绛县| 通江县| 柏乡县| 浦江县| 云和县| 铅山县| 竹山县| 荣昌县| 利川市| 苍山县| 建德市| 吉林省| 祁连县| 贺州市| 金湖县| 岳西县| 宜兴市| 鞍山市| 拉萨市| 沭阳县| 广南县| 丰镇市| 武鸣县| 嘉黎县| 泽普县|