{"id":14158,"date":"2024-03-15T08:34:51","date_gmt":"2024-03-15T08:34:51","guid":{"rendered":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/"},"modified":"2025-08-06T04:40:35","modified_gmt":"2025-08-06T04:40:35","slug":"how-to-use-the-react-drag-and-drop-sorting-component","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/","title":{"rendered":"React Drag-and-Drop Sorting Guide"},"content":{"rendered":"<p>To utilize a drag-and-drop sorting component in React, you first need to install the necessary libraries. The most commonly used libraries are react-dnd and react-dnd-html5-backend.<\/p>\n<ol>\n<li>First, install these two libraries in your project:<\/li>\n<\/ol>\n<pre class=\"post-pre\"><code>npm install react-dnd react-dnd-html5-backend\r\n<\/code><\/pre>\n<ol>\n<li>respond to drag-and-drop<\/li>\n<li>The source from which something can be dragged.<\/li>\n<li>Target for dropping items<\/li>\n<\/ol>\n<pre class=\"post-pre\"><code><span class=\"hljs-keyword\">import<\/span> { <span class=\"hljs-title class_\">DragSource<\/span>, <span class=\"hljs-title class_\">DropTarget<\/span> } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"react-dnd\"<\/span>;\r\n\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title class_\">ItemTypes<\/span> = {\r\n  <span class=\"hljs-attr\">CARD<\/span>: <span class=\"hljs-string\">\"card\"<\/span>\r\n};\r\n\r\n<span class=\"hljs-comment\">\/\/ \u521b\u5efa\u4e00\u4e2aDragSource<\/span>\r\n<span class=\"hljs-keyword\">const<\/span> cardSource = {\r\n  <span class=\"hljs-title function_\">beginDrag<\/span>(<span class=\"hljs-params\">props<\/span>) {\r\n    <span class=\"hljs-keyword\">return<\/span> {\r\n      <span class=\"hljs-attr\">id<\/span>: props.<span class=\"hljs-property\">id<\/span>,\r\n      <span class=\"hljs-attr\">index<\/span>: props.<span class=\"hljs-property\">index<\/span>\r\n    };\r\n  }\r\n};\r\n\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">collectDragSource<\/span> = (<span class=\"hljs-params\">connect, monitor<\/span>) =&gt; {\r\n  <span class=\"hljs-keyword\">return<\/span> {\r\n    <span class=\"hljs-attr\">connectDragSource<\/span>: connect.<span class=\"hljs-title function_\">dragSource<\/span>(),\r\n    <span class=\"hljs-attr\">isDragging<\/span>: monitor.<span class=\"hljs-title function_\">isDragging<\/span>()\r\n  };\r\n};\r\n\r\n<span class=\"hljs-comment\">\/\/ \u521b\u5efa\u4e00\u4e2aDropTarget<\/span>\r\n<span class=\"hljs-keyword\">const<\/span> cardTarget = {\r\n  <span class=\"hljs-title function_\">drop<\/span>(<span class=\"hljs-params\">props, monitor<\/span>) {\r\n    <span class=\"hljs-keyword\">const<\/span> dragIndex = monitor.<span class=\"hljs-title function_\">getItem<\/span>().<span class=\"hljs-property\">index<\/span>;\r\n    <span class=\"hljs-keyword\">const<\/span> hoverIndex = props.<span class=\"hljs-property\">index<\/span>;\r\n\r\n    <span class=\"hljs-comment\">\/\/ \u5728\u8fd9\u91cc\u53ef\u4ee5\u8c03\u7528\u4e00\u4e2a\u56de\u8c03\u51fd\u6570\u6765\u66f4\u65b0\u6392\u5e8f<\/span>\r\n    props.<span class=\"hljs-title function_\">onMove<\/span>(dragIndex, hoverIndex);\r\n  }\r\n};\r\n\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">collectDropTarget<\/span> = (<span class=\"hljs-params\">connect, monitor<\/span>) =&gt; {\r\n  <span class=\"hljs-keyword\">return<\/span> {\r\n    <span class=\"hljs-attr\">connectDropTarget<\/span>: connect.<span class=\"hljs-title function_\">dropTarget<\/span>()\r\n  };\r\n};\r\n\r\n<span class=\"hljs-comment\">\/\/ \u6700\u7ec8\u7684\u53ef\u62d6\u62fd\u7ec4\u4ef6<\/span>\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">DraggableCard<\/span> = (<span class=\"hljs-params\">{ text, isDragging, connectDragSource, connectDropTarget }<\/span>) =&gt; {\r\n  <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-title function_\">connectDragSource<\/span>(\r\n    <span class=\"hljs-title function_\">connectDropTarget<\/span>(\r\n      <span class=\"language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{<\/span> <span class=\"hljs-attr\">opacity:<\/span> <span class=\"hljs-attr\">isDragging<\/span> ? <span class=\"hljs-attr\">0.5<\/span> <span class=\"hljs-attr\">:<\/span> <span class=\"hljs-attr\">1<\/span> }}&gt;<\/span>\r\n        {text}\r\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\r\n    )\r\n  );\r\n};\r\n\r\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-title class_\">DragSource<\/span>(<span class=\"hljs-title class_\">ItemTypes<\/span>.<span class=\"hljs-property\">CARD<\/span>, cardSource, collectDragSource)(\r\n  <span class=\"hljs-title class_\">DropTarget<\/span>(<span class=\"hljs-title class_\">ItemTypes<\/span>.<span class=\"hljs-property\">CARD<\/span>, cardTarget, collectDropTarget)(<span class=\"hljs-title class_\">DraggableCard<\/span>)\r\n);\r\n<\/code><\/pre>\n<ol>\n<li>Create a container component to render a draggable sorting list.<\/li>\n<\/ol>\n<pre class=\"post-pre\"><code><span class=\"hljs-keyword\">import<\/span> { useState } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"react\"<\/span>;\r\n<span class=\"hljs-keyword\">import<\/span> update <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"immutability-helper\"<\/span>;\r\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-title class_\">DraggableCard<\/span> <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/DraggableCard\"<\/span>;\r\n\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">SortableList<\/span> = (<span class=\"hljs-params\"><\/span>) =&gt; {\r\n  <span class=\"hljs-keyword\">const<\/span> [cards, setCards] = <span class=\"hljs-title function_\">useState<\/span>([\r\n    { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">1<\/span>, <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-string\">\"Card 1\"<\/span> },\r\n    { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">2<\/span>, <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-string\">\"Card 2\"<\/span> },\r\n    { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-number\">3<\/span>, <span class=\"hljs-attr\">text<\/span>: <span class=\"hljs-string\">\"Card 3\"<\/span> }\r\n  ]);\r\n\r\n  <span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">handleMoveCard<\/span> = (<span class=\"hljs-params\">dragIndex, hoverIndex<\/span>) =&gt; {\r\n    <span class=\"hljs-keyword\">const<\/span> dragCard = cards[dragIndex];\r\n\r\n    <span class=\"hljs-title function_\">setCards<\/span>(\r\n      <span class=\"hljs-title function_\">update<\/span>(cards, {\r\n        <span class=\"hljs-attr\">$splice<\/span>: [\r\n          [dragIndex, <span class=\"hljs-number\">1<\/span>],\r\n          [hoverIndex, <span class=\"hljs-number\">0<\/span>, dragCard]\r\n        ]\r\n      })\r\n    );\r\n  };\r\n\r\n  <span class=\"hljs-keyword\">return<\/span> (\r\n    <span class=\"language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\r\n      {cards.map((card, index) =&gt; (\r\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">DraggableCard<\/span>\r\n          <span class=\"hljs-attr\">key<\/span>=<span class=\"hljs-string\">{card.id}<\/span>\r\n          <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">{card.id}<\/span>\r\n          <span class=\"hljs-attr\">index<\/span>=<span class=\"hljs-string\">{index}<\/span>\r\n          <span class=\"hljs-attr\">text<\/span>=<span class=\"hljs-string\">{card.text}<\/span>\r\n          <span class=\"hljs-attr\">onMove<\/span>=<span class=\"hljs-string\">{handleMoveCard}<\/span>\r\n        \/&gt;<\/span>\r\n      ))}\r\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\r\n  );\r\n};\r\n\r\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-title class_\">SortableList<\/span>;\r\n<\/code><\/pre>\n<ol>\n<li>List that can be sorted.<\/li>\n<\/ol>\n<pre class=\"post-pre\"><code><span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-title class_\">SortableList<\/span> <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/SortableList\"<\/span>;\r\n\r\n<span class=\"hljs-keyword\">const<\/span> <span class=\"hljs-title function_\">App<\/span> = (<span class=\"hljs-params\"><\/span>) =&gt; {\r\n  <span class=\"hljs-keyword\">return<\/span> (\r\n    <span class=\"language-xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\r\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Sortable List<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\r\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">SortableList<\/span> \/&gt;<\/span>\r\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\r\n  );\r\n};\r\n\r\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-title class_\">App<\/span>;\r\n<\/code><\/pre>\n<p>Now, you can use the drag-and-drop sorting component in the app. When you drag a card and drop it in another position, the list will be re-sorted.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>To utilize a drag-and-drop sorting component in React, you first need to install the necessary libraries. The most commonly used libraries are react-dnd and react-dnd-html5-backend. First, install these two libraries in your project: npm install react-dnd react-dnd-html5-backend respond to drag-and-drop The source from which something can be dragged. Target for dropping items import { DragSource, [&hellip;]<\/p>\n","protected":false},"author":14,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_import_markdown_pro_load_document_selector":0,"_import_markdown_pro_submit_text_textarea":"","footnotes":""},"categories":[1],"tags":[19069,19070,19071,19067,19068],"class_list":["post-14158","post","type-post","status-publish","format-standard","hentry","category-uncategorized","tag-dragsource","tag-droptarget","tag-react-components","tag-react-drag-and-drop","tag-react-dnd"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>React Drag-and-Drop Sorting Guide - Blog - Silicon Cloud<\/title>\n<meta name=\"description\" content=\"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"React Drag-and-Drop Sorting Guide\" \/>\n<meta property=\"og:description\" content=\"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/SiliCloudGlobal\/\" \/>\n<meta property=\"article:published_time\" content=\"2024-03-15T08:34:51+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2025-08-06T04:40:35+00:00\" \/>\n<meta name=\"author\" content=\"Noah Thompson\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@SiliCloudGlobal\" \/>\n<meta name=\"twitter:site\" content=\"@SiliCloudGlobal\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Noah Thompson\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 minute\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\"},\"author\":{\"name\":\"Noah Thompson\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/2e83cc6ab9f60d36921c2d0f9f280f4a\"},\"headline\":\"React Drag-and-Drop Sorting Guide\",\"datePublished\":\"2024-03-15T08:34:51+00:00\",\"dateModified\":\"2025-08-06T04:40:35+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\"},\"wordCount\":95,\"publisher\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/#organization\"},\"keywords\":[\"DragSource\",\"DropTarget\",\"React components\",\"React drag-and-drop\",\"react-dnd\"],\"inLanguage\":\"en-US\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\",\"url\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\",\"name\":\"React Drag-and-Drop Sorting Guide - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/#website\"},\"datePublished\":\"2024-03-15T08:34:51+00:00\",\"dateModified\":\"2025-08-06T04:40:35+00:00\",\"description\":\"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.\",\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/www.silicloud.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"React Drag-and-Drop Sorting Guide\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/blog\/\",\"name\":\"Silicon Cloud Blog\",\"description\":\"\",\"publisher\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/#organization\"},\"inLanguage\":\"en-US\"},{\"@type\":\"Organization\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#organization\",\"name\":\"Silicon Cloud Blog\",\"url\":\"https:\/\/www.silicloud.com\/blog\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#\/schema\/logo\/image\/\",\"url\":\"https:\/\/www.silicloud.com\/blog\/wp-content\/uploads\/2023\/11\/EN-SILICON-Full.png\",\"contentUrl\":\"https:\/\/www.silicloud.com\/blog\/wp-content\/uploads\/2023\/11\/EN-SILICON-Full.png\",\"width\":1024,\"height\":1024,\"caption\":\"Silicon Cloud Blog\"},\"image\":{\"@id\":\"https:\/\/www.silicloud.com\/blog\/#\/schema\/logo\/image\/\"},\"sameAs\":[\"https:\/\/www.facebook.com\/SiliCloudGlobal\/\",\"https:\/\/twitter.com\/SiliCloudGlobal\"]},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/2e83cc6ab9f60d36921c2d0f9f280f4a\",\"name\":\"Noah Thompson\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/350e537e1530ede2762ee0237e877d6693f4f7163ab4f303202cc9a6b27b6cb4?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/350e537e1530ede2762ee0237e877d6693f4f7163ab4f303202cc9a6b27b6cb4?s=96&d=mm&r=g\",\"caption\":\"Noah Thompson\"},\"url\":\"https:\/\/www.silicloud.com\/blog\/author\/noahthompson\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"React Drag-and-Drop Sorting Guide - Blog - Silicon Cloud","description":"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/","og_locale":"en_US","og_type":"article","og_title":"React Drag-and-Drop Sorting Guide","og_description":"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.","og_url":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/","og_site_name":"Blog - Silicon Cloud","article_publisher":"https:\/\/www.facebook.com\/SiliCloudGlobal\/","article_published_time":"2024-03-15T08:34:51+00:00","article_modified_time":"2025-08-06T04:40:35+00:00","author":"Noah Thompson","twitter_card":"summary_large_image","twitter_creator":"@SiliCloudGlobal","twitter_site":"@SiliCloudGlobal","twitter_misc":{"Written by":"Noah Thompson","Est. reading time":"1 minute"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#article","isPartOf":{"@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/"},"author":{"name":"Noah Thompson","@id":"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/2e83cc6ab9f60d36921c2d0f9f280f4a"},"headline":"React Drag-and-Drop Sorting Guide","datePublished":"2024-03-15T08:34:51+00:00","dateModified":"2025-08-06T04:40:35+00:00","mainEntityOfPage":{"@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/"},"wordCount":95,"publisher":{"@id":"https:\/\/www.silicloud.com\/blog\/#organization"},"keywords":["DragSource","DropTarget","React components","React drag-and-drop","react-dnd"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/","url":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/","name":"React Drag-and-Drop Sorting Guide - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/blog\/#website"},"datePublished":"2024-03-15T08:34:51+00:00","dateModified":"2025-08-06T04:40:35+00:00","description":"Learn how to implement React drag-and-drop sorting with react-dnd and react-dnd-html5-backend libraries in this easy tutorial.","breadcrumb":{"@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/blog\/how-to-use-the-react-drag-and-drop-sorting-component\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.silicloud.com\/blog\/"},{"@type":"ListItem","position":2,"name":"React Drag-and-Drop Sorting Guide"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/blog\/#website","url":"https:\/\/www.silicloud.com\/blog\/","name":"Silicon Cloud Blog","description":"","publisher":{"@id":"https:\/\/www.silicloud.com\/blog\/#organization"},"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/www.silicloud.com\/blog\/#organization","name":"Silicon Cloud Blog","url":"https:\/\/www.silicloud.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.silicloud.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/www.silicloud.com\/blog\/wp-content\/uploads\/2023\/11\/EN-SILICON-Full.png","contentUrl":"https:\/\/www.silicloud.com\/blog\/wp-content\/uploads\/2023\/11\/EN-SILICON-Full.png","width":1024,"height":1024,"caption":"Silicon Cloud Blog"},"image":{"@id":"https:\/\/www.silicloud.com\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/SiliCloudGlobal\/","https:\/\/twitter.com\/SiliCloudGlobal"]},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/2e83cc6ab9f60d36921c2d0f9f280f4a","name":"Noah Thompson","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.silicloud.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/350e537e1530ede2762ee0237e877d6693f4f7163ab4f303202cc9a6b27b6cb4?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/350e537e1530ede2762ee0237e877d6693f4f7163ab4f303202cc9a6b27b6cb4?s=96&d=mm&r=g","caption":"Noah Thompson"},"url":"https:\/\/www.silicloud.com\/blog\/author\/noahthompson\/"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/posts\/14158","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/users\/14"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/comments?post=14158"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/posts\/14158\/revisions"}],"predecessor-version":[{"id":158181,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/posts\/14158\/revisions\/158181"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/media?parent=14158"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/categories?post=14158"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/blog\/wp-json\/wp\/v2\/tags?post=14158"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}