ساخت ابزارهای Drag and Drop در React با استفاده از React DnD
صادق جعفری
صادق جعفری

از کودکی به کامپیوتر و دنیای دیجیتال علاقه داشتم، به همین دلیل ترک تحصیل کردم و تمام تلاش خودم را صرفا برای یادگیری کامپیوتر، طراحی، برنامه نویسی و ... به کار گرفتم. در کنار مشاغل مختلفی که مجبور به انجامشان بودم برنامه نویسی را یاد گرفتم و از سال 1390 وارد بازار کار شدم و همیشه در تلاش هستم تا چالش های روبرو را با موفقیت پشت سر بگذارم.

شبکه های اجتماعی من

سلام دوستان، من صادق جعفری هستم و امروز می‌خواهم در مورد ساخت ابزارهای Drag and Drop در React با استفاده از کتابخانه قدرتمند React DnD صحبت کنم. این موضوع می‌تواند برای هر کسی که در زمینه توسعه وب با React فعالیت می‌کند، بسیار جذاب و کاربردی باشد. امیدوارم که این راهنما به شما کمک کند تا بتوانید قابلیت‌های کشیدن و رها کردن را به سادگی و به صورت بهینه در پروژه‌های خود پیاده‌سازی کنید.

اول از همه، بیایید ببینیم که چرا باید از React DnD استفاده کنیم. این کتابخانه یکی از بهترین گزینه‌ها برای پیاده‌سازی قابلیت‌های Drag and Drop در اپلیکیشن‌های React است. دلیل آن هم این است که React DnD به شما اجازه می‌دهد تا با استفاده از APIهای ساده و کاربرپسند، به راحتی این قابلیت‌ها را در پروژه‌های خود اضافه کنید. علاوه بر این، React DnD از نظر عملکرد و کارایی بسیار بهینه است و می‌تواند با حجم زیادی از داده‌ها به خوبی کار کند.

یکی از مهم‌ترین چیزهایی که باید در مورد React DnD بدانید، این است که این کتابخانه از الگوی higher-order components (HOCs) برای ایجاد قابلیت‌های Drag and Drop استفاده می‌کند. این بدان معناست که شما می‌توانید با استفاده از HOCs، کامپوننت‌های خود را به راحتی به قابلیت‌های Drag and Drop مجهز کنید. در ادامه، ما به بررسی چگونگی پیاده‌سازی این الگو در پروژه‌های واقعی خواهیم پرداخت.

حالا بیایید نگاهی به مراحل نصب و راه‌اندازی React DnD بیندازیم. ابتدا باید کتابخانه‌های لازم را نصب کنیم. برای این کار، می‌توانید از npm یا yarn استفاده کنید. دستورات زیر را در ترمینال خود اجرا کنید:

npm install react-dnd react-dnd-html5-backend
 

یا

yarn add react-dnd react-dnd-html5-backend

بعد از نصب این کتابخانه‌ها، باید آن‌ها را در پروژه خود وارد کنید. برای این کار، ابتدا باید Provider را در بالاترین سطح اپلیکیشن خود اضافه کنید. این کار را می‌توانید به شکل زیر انجام دهید:

import { DndProvider } from 'react-dnd';
import { HTML5Backend } from 'react-dnd-html5-backend';

function App() {
  return (
    <DndProvider backend={HTML5Backend}>
      {/* سایر کامپوننت‌ها */}
    </DndProvider>
  );
}

 

حالا که Provider را اضافه کردیم، می‌توانیم به سراغ ساخت کامپوننت‌های Drag و Drop برویم. در اینجا، ما یک مثال ساده از یک آیتم کشیدنی و یک ناحیه رها کردنی را بررسی می‌کنیم. ابتدا باید کامپوننت DragItem را بسازیم:

import { useDrag } from 'react-dnd';

function DragItem({ id }) {
  const [{ isDragging }, drag] = useDrag(() => ({
    type: 'BOX',
    item: { id },
    collect: (monitor) => ({
      isDragging: !!monitor.isDragging(),
    }),
  }));

  return (
    <div ref={drag} style={{ opacity: isDragging ? 0.5 : 1 }}>
      آیتم {id}
    </div>
  );
}

در اینجا، ما از هوک useDrag برای ایجاد یک آیتم کشیدنی استفاده کرده‌ایم. نوع آیتم را 'BOX' قرار داده‌ایم و از ویژگی collect برای تغییر استایل آیتم هنگام کشیده شدن استفاده می‌کنیم.

سپس، باید یک DropArea بسازیم تا بتوانیم آیتم‌های کشیده شده را در آن رها کنیم:

import { useDrop } from 'react-dnd';

function DropArea({ onDrop }) {
  const [{ isOver }, drop] = useDrop(() => ({
    accept: 'BOX',
    drop: (item) => onDrop(item.id),
    collect: (monitor) => ({
      isOver: !!monitor.isOver(),
    }),
  }));

  return (
    <div ref={drop} style={{ background: isOver ? 'lightgreen' : 'white' }}>
      ناحیه رها کردن
    </div>
  );
}

 

در اینجا، ما از هوک useDrop برای ایجاد یک ناحیه رها کردنی استفاده کرده‌ایم. نوع آیتم‌های پذیرفته شده را 'BOX' قرار داده‌ایم و از ویژگی collect برای تغییر استایل ناحیه هنگام رها کردن آیتم‌ها استفاده می‌کنیم.

اکنون، می‌توانیم این دو کامپوننت را در اپلیکیشن خود به کار ببریم و قابلیت Drag and Drop را پیاده‌سازی کنیم:

function App() {
  const handleDrop = (id) => {
    console.log(`آیتم ${id} رها شد`);
  };

  return (
    <DndProvider backend={HTML5Backend}>
      <DragItem id={1} />
      <DropArea onDrop={handleDrop} />
    </DndProvider>
  );
}

 

حالا که همه چیز آماده است، شما باید بتوانید آیتم کشیدنی خود را بگیرید و در ناحیه رها کردنی رها کنید. این یک مثال ساده بود، اما با همین اصول می‌توانید قابلیت‌های پیشرفته‌تری مانند Drag and Drop چندین آیتم، نواحی مختلف و حتی لیست‌های مرتب‌شدنی را پیاده‌سازی کنید.

 

در نهایت، امیدوارم این مقاله به شما کمک کرده باشد تا با کتابخانه React DnD آشنا شوید و بتوانید از آن در پروژه‌های خود استفاده کنید. اگر سوال یا نظری دارید، خوشحال می‌شوم که در بخش نظرات با من در میان بگذارید. موفق باشید و تا مقاله بعدی، خدانگهدار!

ارسال دیدگاه