찾다
웹 프론트엔드프런트엔드 Q&AReact-dnd가 드래그 앤 드롭을 구현하는 방법

구현 방법: 1. "import{DndProvider}from 'react-dnd'"를 사용하여 드래그 가능한 범위를 정의합니다. 2. "import{useDrag}from 'react-dnd'"를 사용하여 구성 요소 주위에 DragSource를 래핑합니다. 드래그할 수 있습니다.

React-dnd가 드래그 앤 드롭을 구현하는 방법

이 튜토리얼의 운영 환경: Windows 10 시스템, 반응 버전 17.0.1, Dell G3 컴퓨터.

react-dnd로 드래그 앤 드롭을 구현하는 방법

React DnD는 React 및 Redux의 핵심 작성자인 Dan Abramov가 만든 React 고차원 구성 요소 집합으로, 복잡한 드래그 앤 드롭 인터페이스를 구축하는 데 도움을 줄 수 있습니다. 구성 요소를 분리하여 유지합니다.

React DnD 요구 사항

  • 기본적으로 HTML5 드래그 앤 드롭 API를 사용하지만

  • DOM을 직접 운영하지 않음

  • DOM 및 드래그 앤 드롭 소스 및 타겟 디커플링

  • 을 지원합니다.

    HTML5 드래그 앤 드롭으로 유형 일치 및 데이터 전달 아이디어를 훔치는 통합

React DnD의 특징

기성 구성 요소를 제공하지 않고 드래그 앤 드롭에 집중

React DnD가 제공하는 것 강력한 프리미티브 세트이지만 기성 컴포넌트를 포함하지 않고 사용자 컴포넌트를 래핑하고 소품을 주입합니다. jQuery UI 등보다 낮은 수준으로 드래그 앤 드롭 상호 작용을 올바르게 만드는 데 중점을 두고 좌표 제한과 같은 시각적 효과를 사용자에게 맡깁니다. 이는 실제로 우려 사항 분리의 원칙입니다. 예를 들어 React DnD는 정렬 가능한 구성 요소를 제공할 의도가 없지만 사용자는 이를 기반으로 필요한 사용자 정의 정렬 가능한 구성 요소를 빠르게 개발할 수 있습니다.

단방향 데이터 흐름

React와 유사하게 선언적 렌더링을 채택하고 redux와 같은 단방향 데이터 흐름 아키텍처를 사용합니다. 실제로 Redux는 내부적으로 사용됩니다

플랫폼의 기본 API 문제를 숨깁니다

HTML5 드래그 앤 드롭 API는 문제점과 브라우저 불일치로 가득 차 있습니다. React DnD는 이를 내부적으로 처리하므로 소비자는 브라우저 문제를 해결하는 대신 애플리케이션 개발에 집중할 수 있습니다.

확장 가능하고 테스트 가능

React DnD는 기본적으로 HTML5 드래그 앤 드롭 API 래퍼를 제공하지만 사용자 정의 "백엔드"를 제공할 수도 있습니다. 터치 이벤트, 마우스 이벤트 또는 기타 사항을 기반으로 사용자 지정 DnD 백엔드를 만들 수 있습니다. 예를 들어, 내장된 모의 백엔드를 사용하면 노드 환경에서 구성 요소의 드래그 앤 드롭 상호 작용을 테스트할 수 있습니다.

미래 준비

React DnD는 믹스인을 내보내지 않으며 ES6 클래스, createReactClass 또는 기타 React 프레임워크를 사용하여 생성된 모든 구성 요소와 동일하게 작동합니다. 그리고 API는 ES7 데코레이터를 지원합니다.

예는 다음과 같습니다.

1.1. DndProvider를 사용하여 드래그 가능한 범위를 정의합니다

/*
 * @Author: muge
 * @Date: 2021-12-04 16:59:25
 * @LastEditors: Please set LastEditors
 * @LastEditTime: 2021-12-08 14:24:47
 */
import React, { useState } from 'react';
import { DndProvider } from 'react-dnd';
import { HTML5Backend } from 'react-dnd-html5-backend';
import SourceBox from './SourceBox';
import TargetBox from './TargetBox';
import TreeBox from './TreeBox';
const item: any[] = [
  {
    id: 1,
    name: 'muge',
  },
  {
    id: 2,
    name: 'muxi',
  },
  {
    id: 3,
    name: 'mugege',
  },
];
const Container = () => {
  // 当前拖拽项
  const [currentList, setCurrentList] = useState<any>({});
  return (
    // 类似redux数据传输  需要在最外层包裹对象
    <DndProvider backend={HTML5Backend}>
      <h1 id="拖拽源组件-nbsp-列表-树">拖拽源组件 列表-----树</h1>
      <div style={{ display: &#39;flex&#39; }}>
        <div>
          {/* 列表拖拽源 */}
          {item.map((itemz: any, index: number) => (
            <SourceBox setCurrentList={setCurrentList} item={itemz} key={index} />
          ))}
        </div>
        {/* 注意,不要树组件整体直接设置拖拽,抽成一个组件来遍历每一项 =》自定义渲染*/}
        {/* 树形拖拽源 */}
        <TreeBox />
      </div>
      <h1 id="拖拽放置目标">拖拽放置目标</h1>
      {/* 拖拽最终放置组件 */}
      <TargetBox currentList={currentList} />
    </DndProvider>
  );
};
export default Container;

2. 드래그할 수 있도록 DragSource를 사용하여 컴포넌트를 래핑합니다.

/*
 * @Author: muge
 * @Date: 2021-12-07 14:26:08
 * @LastEditors: Please set LastEditors
 * @LastEditTime: 2021-12-08 14:18:52
 */
import { useDrag } from &#39;react-dnd&#39;;
const ItemTypes = {
  BOX: &#39;box&#39;,
};
const style = {
  border: &#39;1px dashed gray&#39;,
  backgroundColor: &#39;white&#39;,
  padding: &#39;0.5rem 1rem&#39;,
  marginRight: &#39;1rem&#39;,
  marginBottom: &#39;1rem&#39;,
  cursor: &#39;move&#39;,
};
const SourceBox = ({ item, setCurrentList }: any) => {
  const [{ opacity }, drag] = useDrag(
    () => ({
      type: ItemTypes.BOX,
      collect: (monitor) => ({
        opacity: monitor.isDragging() ? 0.4 : 1,
      }),
      item: () => item, //返回当前列表项数据
      canDrag: (monitor) => {
        //是否取消拖拽
        console.log(monitor, &#39;monitor131&#39;);
        return true;
      },
      //
      end(currentItem, monitor) {
        // monitor.getDropResult(); //获取拖拽对象所处容器的数据
        // monitor.didDrop(); // 当前容器能否放置拖拽对象 拖动停止时触发
        monitor.didDrop() && setCurrentList(currentItem); //在容器点松开 才赋值
      },
    }),
    [],
  );
  return (
    <div ref={drag} style={{ ...style, opacity }}>
      {item.id}------{item.name}
    </div>
  );
};
export default SourceBox;

3. , 호환되는 항목을 드래그하거나 가리키거나 놓을 때 반응하도록 만드세요.

/*
 * @Author: muge
 * @Date: 2021-12-07 14:26:08
 * @LastEditors: Please set LastEditors
 * @LastEditTime: 2021-12-08 14:33:08
 */
import React from &#39;react&#39;;
import { useDrop } from &#39;react-dnd&#39;;
const ItemTypes = {
  BOX: &#39;box&#39;,
};
const style: any = {
  border: &#39;1px solid gray&#39;,
  height: &#39;15rem&#39;,
  width: &#39;15rem&#39;,
  padding: &#39;2rem&#39;,
  textAlign: &#39;center&#39;,
};
const TargetBox = ({ currentList }: any) => {
  const [{ isActive, isOver, canDrop }, drop] = useDrop(() => ({
    accept: ItemTypes.BOX,
    collect: (monitor) => ({
      isActive: monitor.canDrop() && monitor.isOver(),
      isOver: monitor.isOver(),
      canDrop: monitor.canDrop(),
    }),
    // hover: (item, monitor) => {
    //   console.log(item, &#39;item&#39;);
    //   console.log(monitor, &#39;monitor&#39;);
    // },
  }));
  // console.log(isOver, &#39;isOver&#39;);
  // console.log(canDrop, &#39;canDrop&#39;);
  return (
    <div ref={drop} style={style}>
      {isActive ? &#39;Release to drop&#39; : &#39;Drag item here&#39;}
      <div
        style={{
          backgroundColor: &#39;pink&#39;,
          height: 30,
          display: &#39;flex&#39;,
          alignItems: &#39;center&#39;,
          justifyContent: &#39;center&#39;,
          fontSize: 17,
          fontWeight: 600,
          width: &#39;100%&#39;,
        }}
      >
        {JSON.stringify(currentList) !== &#39;{}&#39; ? JSON.stringify(currentList) : &#39;当前item&#39;}
      </div>
    </div>
  );
};
export default TargetBox;

완료하려면 이 목록에 드래그 앤 드롭하세요

권장 학습: "react 비디오 튜토리얼"

위 내용은 React-dnd가 드래그 앤 드롭을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
HTML 및 React의 통합 : 실용 가이드HTML 및 React의 통합 : 실용 가이드Apr 21, 2025 am 12:16 AM

HTML 및 React는 JSX를 통해 완벽하게 통합하여 효율적인 사용자 인터페이스를 구축 할 수 있습니다. 1) JSX를 사용하여 HTML 요소를 포함시킵니다. 2) Virtual DOM을 사용하여 렌더링 성능을 최적화, 3) 구성 요소화를 통해 HTML 구조를 관리하고 렌더링합니다. 이 통합 방법은 직관적 일뿐 만 아니라 응용 프로그램 성능을 향상시킵니다.

React 및 HTML : 데이터 렌더링 및 처리 이벤트React 및 HTML : 데이터 렌더링 및 처리 이벤트Apr 20, 2025 am 12:21 AM

상태 및 소품을 통해 데이터를 효율적으로 렌더링하고 합성 이벤트 시스템을 통해 사용자 이벤트를 처리합니다. 1) usestate를 사용하여 카운터 예제와 같은 상태를 관리하십시오. 2) 버튼 클릭과 같은 JSX에 함수를 추가하여 이벤트 처리가 구현됩니다. 3) Todolist 구성 요소와 같은 목록을 렌더링하려면 주요 속성이 필요합니다. 4) 양식 처리의 경우 양식 구성 요소와 같은 usestate 및 e.preventDefault ().

백엔드 연결 : 반응이 서버와 상호 작용하는 방법백엔드 연결 : 반응이 서버와 상호 작용하는 방법Apr 20, 2025 am 12:19 AM

반응은 HTTP 요청을 통해 서버와 상호 작용하여 데이터를 획득, 전송, 업데이트 및 삭제합니다. 1) 사용자 작동 이벤트 트리거, 2) HTTP 요청 시작, 3) 프로세스 서버 응답, 4) 구성 요소 상태 및 재 렌더 업데이트.

React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.React : 사용자 인터페이스 (Frontend)에 중점을 둡니다.Apr 20, 2025 am 12:18 AM

React는 구성 요소 개발 및 가상 DOM을 통해 효율성을 향상시키는 사용자 인터페이스를 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 JSX : JSX 구문을 사용하여 구성 요소를 정의하여 코드 직관과 품질을 향상시킵니다. 2. 가상 DOM 및 렌더링 : 가상 DOM 및 DIFF 알고리즘을 통해 렌더링 성능을 최적화합니다. 3. 상태 관리 및 고리 : usestate 및 useffect와 같은 후크는 상태 관리 및 부작용 처리를 단순화합니다. 4. 사용의 예 : 기본 양식에서 고급 글로벌 주 관리에 이르기까지 ContextApi를 사용하십시오. 5. 일반적인 오류 및 디버깅 : 부적절한 상태 관리 및 구성 요소 업데이트 문제를 피하고 ReactDevTools를 사용하여 디버그를 사용하십시오. 6. 성능 최적화 및 최적 성

React의 역할 : 프론트 엔드 또는 백엔드? 구별을 명확하게합니다React의 역할 : 프론트 엔드 또는 백엔드? 구별을 명확하게합니다Apr 20, 2025 am 12:15 AM

Reactisafrontendlibrary, FocusedOnBuildingUserInterfaces.itmanagesUistateAndatesefficiplyingavirtudom 및 BackingServicesViaApforDataHandling, ButDoessorsorstoredAtaitiate 스스로.

HTML에서 반응 : 대화식 사용자 인터페이스 구축HTML에서 반응 : 대화식 사용자 인터페이스 구축Apr 20, 2025 am 12:05 AM

RECT는 HTML에 내장되어 기존 HTML 페이지를 향상 시키거나 완전히 다시 작성할 수 있습니다. 1) RECT를 사용하기위한 기본 단계에는 HTML에 루트 DIV를 추가하고 ReactDom.render ()를 통해 React 구성 요소를 렌더링하는 것이 포함됩니다. 2) 더 고급 응용 프로그램에는 usestate를 사용하여 상태를 관리하고 카운터 및 할 일 목록과 같은 복잡한 UI 상호 작용을 구현하는 것이 포함됩니다. 3) 최적화 및 모범 사례에는 코드 세분화, 게으른 하중 및 React.Memo 및 Usememo 사용이 포함됩니다. 이러한 방법을 통해 개발자는 React의 힘을 활용하여 동적 및 반응 형 사용자 인터페이스를 구축 할 수 있습니다.

React : 현대 프론트 엔드 개발의 기초React : 현대 프론트 엔드 개발의 기초Apr 19, 2025 am 12:23 AM

React는 현대적인 프론트 엔드 애플리케이션을 구축하기위한 JavaScript 라이브러리입니다. 1. 구성 요소 및 가상 DOM을 사용하여 성능을 최적화합니다. 2. 구성 요소는 JSX를 사용하여 데이터를 관리하기 위해 정의, 상태 및 속성을 정의합니다. 3. 고리는 수명주기 관리를 단순화합니다. 4. ContextApi를 사용하여 글로벌 상태를 관리하십시오. 5. 일반적인 오류는 디버깅 상태 업데이트 및 수명주기가 필요합니다. 6. 최적화 기술에는 메모 화, 코드 분할 및 가상 스크롤이 포함됩니다.

React의 미래 : 웹 개발의 트렌드와 혁신React의 미래 : 웹 개발의 트렌드와 혁신Apr 19, 2025 am 12:22 AM

React의 미래는 궁극적 인 구성 요소 개발, 성능 최적화 및 다른 기술 스택과의 깊은 통합에 중점을 둘 것입니다. 1) RECT는 구성 요소의 생성 및 관리를 더욱 단순화하고 궁극적 인 구성 요소 개발을 촉진합니다. 2) 성능 최적화는 특히 대규모 응용 프로그램에서 초점이됩니다. 3) React는 개발 경험을 향상시키기 위해 GraphQL 및 TypeScript와 같은 기술과 깊이 통합 될 것입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!