{"id":15378,"date":"2024-01-11T15:48:21","date_gmt":"2024-01-11T12:18:21","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/"},"modified":"2024-01-11T15:48:21","modified_gmt":"2024-01-11T12:18:21","slug":"%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/","title":{"rendered":"\u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a Vanilla \u0639\u0645\u0644 \u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0622\u06cc\u062a\u0645 \u06cc\u0627 \u062a\u06a9\u0647\u200c\u0627\u06cc \u0627\u0632 \u0645\u062a\u0646\u060c \u062c\u0627\u0628\u062c\u0627\u06cc\u06cc \u0622\u0646 (\u06a9\u0634\u06cc\u062f\u0646) \u0648 \u0633\u067e\u0633 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 (\u0631\u0647\u0627 \u06a9\u0631\u062f\u0646) \u062f\u0631 \u0645\u06a9\u0627\u0646\u06cc \u062f\u06cc\u06af\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.  \u0627\u06a9\u062b\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u062a\u0646\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u062a\u0635\u0627\u0648\u06cc\u0631 \u06cc\u0627 \u0646\u0634\u0627\u0646\u200c\u0648\u0627\u0631\u0647\u200c\u0647\u0627\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0635\u0648\u06cc\u0631 \u0631\u0627 \u0628\u06a9\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 &#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_html5_drag_and_drop_api\" >\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 HTML5 Drag and Drop API+<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%da%a9%d8%b4%db%8c%d8%af%d9%86_%d9%88_%d8%b1%d9%87%d8%a7_%da%a9%d8%b1%d8%af%d9%86_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7\" >\u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d8%b4%d8%b1%d9%88%d8%b9_%d8%b4%d8%af%d9%86\" >\u0634\u0631\u0648\u0639 \u0634\u062f\u0646<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d9%88%da%98%d9%87_%d9%88_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%a7%d9%88%d9%84%db%8c%d9%87\" >\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0648\u0698\u0647 \u0648 \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7%db%8c_drag-and-drop_%d8%a8%d8%a7_%d8%ac%d8%a7%d9%88%d8%a7_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa\" >\u0645\u062f\u06cc\u0631\u06cc\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc Drag-and-Drop \u0628\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_drag_and_drop_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_sortablejs\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc Drag and Drop \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 SortableJS<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%da%a9%d8%b4%db%8c%d8%af%d9%86-%d9%88-%d8%b1%d9%87%d8%a7-%da%a9%d8%b1%d8%af%d9%86-%d8%af%d8%b1-%d8%ac%d8%a7%d9%88%d8%a7-%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa-vanilla-%d8%b9%d9%85%d9%84-%d8%a7\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0639\u0645\u0644 \u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u06cc\u0627 \u062a\u06a9\u0647 \u0627\u06cc \u0627\u0632 \u0645\u062a\u0646\u060c \u062c\u0627\u0628\u062c\u0627\u06cc\u06cc \u0622\u0646 (<em>\u06a9\u0634\u06cc\u062f\u0646<\/em>) \u0648 \u0633\u067e\u0633 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 (<em>\u0627\u0646\u062f\u0627\u062e\u062a\u0646<\/em>) \u062f\u0631 \u0645\u06a9\u0627\u0646 \u062f\u06cc\u06af\u0631\u06cc \u062a\u0648\u0635\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a <em><strong>\u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646<\/strong><\/em>.<\/p>\n<p>\u0627\u06a9\u062b\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u062a\u0646\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c \u0627\u06af\u0631 \u062a\u0635\u0627\u0648\u06cc\u0631 \u06cc\u0627 \u0644\u0648\u06af\u0648\u062a\u0627\u06cc\u067e \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0635\u0648\u06cc\u0631 \u0631\u0627 \u0645\u06cc \u06a9\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a\u060c \u06cc\u06a9 &#8220;<em>\u062a\u0635\u0648\u06cc\u0631 \u0631\u0648\u062d<\/em>&#8220;\u0638\u0627\u0647\u0631 \u062e\u0648\u0627\u0647\u062f \u0634\u062f (\u0627\u06cc\u0646 \u0628\u0631\u0627\u06cc SVG \u06a9\u0627\u0631 \u0646\u0645\u06cc \u06a9\u0646\u062f \u060c \u0632\u06cc\u0631\u0627 \u0627\u06cc\u0646 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0646\u06cc\u0633\u062a\u0646\u062f).<\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0628\u0631\u0627\u06cc \u062a\u0647\u06cc\u0647 \u0627\u0646\u0648\u0627\u0639 \u062f\u06cc\u06af\u0631 \u0645\u062d\u062a\u0648\u0627 \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u060c \u0628\u0627\u06cc\u062f \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <em>HTML5 Drag and Drop (DnD) APIs<\/em> \u06cc\u0627 \u06cc\u06a9 <em>\u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u062e\u0627\u0631\u062c\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<\/em>.<\/p>\n<\/p><\/div><\/div><\/div>\n<blockquote>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u062f\u0633\u062a \u0647\u0627 \u0631\u0648\u06cc \u0631\u0627\u0647\u0646\u0645\u0627\u06cc\u060c \u0645\u0627 \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u0634\u062a <em>\u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0627\u0646\u062f\u0627\u062e\u062a\u0646<\/em> \u062f\u0631 JavaScript \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 API Drag \u0648 Drop (DND) \u0648 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 JavaScript \u062e\u0627\u0631\u062c\u06cc \u060c <a target=\"_blank\" rel=\"nofollow noopener\" href=\"https:\/\/sortablejs.github.io\/Sortable\/\">\u0642\u0627\u0628\u0644 \u0645\u0631\u062a\u0628 \u0633\u0627\u0632\u06cc<\/a>.<\/p>\n<\/blockquote>\n<p>\u062a\u062e\u062a\u0647 Kanban \u0628\u0633\u06cc\u0627\u0631 \u0645\u062d\u0628\u0648\u0628 \u060c Trello \u060c \u0627\u0632 Drag-and-Drop \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u062d\u0631\u06a9\u0627\u062a \u06a9\u0627\u0631\u062a \u0631\u0627 \u0627\u0632 \u06cc\u06a9 \u0644\u06cc\u0633\u062a \u0628\u0647 \u0644\u06cc\u0633\u062a \u062f\u06cc\u06af\u0631 \u0622\u0633\u0627\u0646\u062a\u0631 \u06a9\u0646\u062f!  \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627 \u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u0686\u06cc\u0632\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0645\u0634\u0627\u0628\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0648\u062f.<\/p>\n<h3 id=\"usingthehtml5draganddropapi\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_html5_drag_and_drop_api\"><\/span>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 HTML5 Drag and Drop API+<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u062f\u0631 HTML4 \u0645\u0639\u0645\u0648\u0644\u06cc\u060c \u062a\u0648\u0633\u0639\u0647\u200c\u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0645\u062c\u0628\u0648\u0631 \u0628\u0648\u062f\u0646\u062f \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0646\u0648\u06cc\u0633\u06cc \u062f\u0634\u0648\u0627\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06cc\u0627 \u0633\u0627\u06cc\u0631 \u0686\u0627\u0631\u0686\u0648\u0628\u200c\u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0627\u0646\u0646\u062f jQuery \u0648 \u063a\u06cc\u0631\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f\u060c \u0627\u0645\u0627 HTML 5 \u06cc\u06a9 API Drag and Drop (DnD) \u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f \u06a9\u0647 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc DnD \u0628\u0648\u0645\u06cc \u0631\u0627 \u0628\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f. \u06a9\u062f \u06a9\u0631\u062f\u0646 \u062e\u06cc\u0644\u06cc \u0631\u0627\u062d\u062a \u062a\u0631\u0647<\/p>\n<blockquote>\n<p>\u06a9\u0644\u06cc\u0647 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627\u06cc \u0627\u0635\u0644\u06cc \u060c \u0627\u0632 \u062c\u0645\u0644\u0647 Chrome \u060c Firefox 3.5 \u0648 Safari 4 \u060c \u0627\u0632 \u0627\u06cc\u0646 HTML 5 DND \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<\/blockquote>\n<p>\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0639\u0645\u0644\u0627 \u0647\u0631 \u0639\u0646\u0635\u0631\u06cc \u0631\u0627 \u0628\u0633\u0627\u0632\u06cc\u0645 \u0631\u0648\u06cc \u0648\u0628 \u0633\u0627\u06cc\u062a \u0645\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 API \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0627\u0633\u062a.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0627\u0648\u0633 \u060c \u06a9\u0627\u0631\u0628\u0631 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u0648\u0627\u0631\u062f \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u062f \u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 A \u0628\u06a9\u0634\u06cc\u062f <em>\u0642\u0627\u0628\u0644 \u0631\u0647\u0627 \u0634\u062f\u0646<\/em> \u0639\u0646\u0635\u0631 \u060c \u0633\u067e\u0633 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0646\u062a\u0634\u0627\u0631 \u062f\u06a9\u0645\u0647 \u0645\u0627\u0648\u0633 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u062f.  \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0628\u0627\u0639\u062b \u0645\u06cc \u0634\u0648\u062f \u0627\u0632 \u0627\u0644\u06af\u0648\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f DOM \u0648 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc Drag and Drop \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f.<\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0686\u0646\u062f\u06cc\u0646 \u0646\u0648\u0639 \u0631\u0648\u06cc\u062f\u0627\u062f \u062f\u0631 \u0637\u0648\u0644 \u0639\u0645\u0644\u06cc\u0627\u062a \u062f\u0631\u06af \u0627\u062e\u0631\u0627\u062c \u0645\u06cc \u0634\u0648\u0646\u062f \u0648 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u062e\u0627\u0635\u06cc \u0645\u0627\u0646\u0646\u062f \u0645\u0648\u0627\u0631\u062f <code>drag<\/code> \u0648 <code>dragover<\/code> \u062d\u0648\u0627\u062f\u062b\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0686\u0646\u062f\u06cc\u0646 \u0628\u0627\u0631 \u0634\u0644\u06cc\u06a9 \u0634\u0648\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<h3 id=\"draganddropevents\"><span class=\"ez-toc-section\" id=\"%da%a9%d8%b4%db%8c%d8%af%d9%86_%d9%88_%d8%b1%d9%87%d8%a7_%da%a9%d8%b1%d8%af%d9%86_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7\"><\/span>\u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u062f\u0631 \u0645\u0631\u0627\u062d\u0644 \u0645\u062e\u062a\u0644\u0641 \u0631\u0648\u0634 \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u0634\u062f\u0646 \u0622\u063a\u0627\u0632 \u0645\u06cc \u0634\u0648\u0646\u062f:<\/p>\n<ul>\n<li><strong>\u06a9\u0634\u06cc\u062f\u0646 \u0634\u0631\u0648\u0639:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0634\u0631\u0648\u0639 \u0628\u0647 \u06a9\u0634\u06cc\u062f\u0646 \u0645\u0648\u0631\u062f \u0645\u06cc \u06a9\u0646\u062f \u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u062e \u0645\u06cc \u062f\u0647\u062f.<\/li>\n<li><strong>\u062f\u0631\u0627\u062c\u0646\u062a\u0631:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0627\u0648\u0633 \u0628\u0631\u0627\u06cc \u0627\u0648\u0644\u06cc\u0646 \u0628\u0627\u0631 \u0647\u0646\u06af\u0627\u0645 \u06a9\u0634\u06cc\u062f\u0646 \u0631\u0648\u06cc \u0639\u0646\u0635\u0631 \u0647\u062f\u0641 \u062d\u0631\u06a9\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0641\u0639\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li><strong>\u06a9\u0634\u0646\u062f\u0647:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06cc\u06a9 \u06a9\u0634\u06cc\u062f\u0646 \u0631\u062e \u0645\u06cc \u062f\u0647\u062f \u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0648\u0634 \u0628\u0631 \u0631\u0648\u06cc \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u06a9\u0634\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u060c \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u062f.  \u0631\u0627 process \u0627\u062a\u0641\u0627\u0642\u06cc \u06a9\u0647 \u062f\u0631 \u0637\u0648\u0644 \u06cc\u06a9 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u062e \u0645\u06cc\u200c\u062f\u0647\u062f\u060c \u063a\u0627\u0644\u0628\u0627\u064b \u0645\u0627\u0646\u0646\u062f \u0631\u0648\u06cc\u062f\u0627\u062f dragenter \u0627\u0633\u062a.<\/li>\n<li><strong>\u06a9\u0634\u06cc\u062f\u0646 \u06af\u0644\u0648\u0644\u0647:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0627\u0648\u0633 \u0647\u0646\u06af\u0627\u0645 \u06a9\u0634\u06cc\u062f\u0646 \u0639\u0646\u0635\u0631\u06cc \u0631\u0627 \u062a\u0631\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li><strong>\u06a9\u0634\u06cc\u062f\u0646:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0627\u0648\u0633 \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0645\u0648\u0631\u062f \u062f\u0631 \u062d\u0627\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0627\u0633\u062a \u062d\u0631\u06a9\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0641\u0639\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li><strong>\u0631\u0647\u0627 \u06a9\u0631\u062f\u0646:<\/strong> \u067e\u0633 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645 \u0639\u0645\u0644\u06cc\u0627\u062a \u06a9\u0634\u06cc\u062f\u0646\u060c <code>drop<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u062e\u0631\u0627\u062c \u0645\u06cc \u0634\u0648\u062f \u0631\u0648\u06cc \u0639\u0646\u0635\u0631\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0633\u0642\u0648\u0637 \u0631\u062e \u062f\u0627\u062f\u0647 \u0627\u0633\u062a.  \u06cc\u06a9 \u0634\u0646\u0648\u0646\u062f\u0647 \u0645\u0633\u0626\u0648\u0644 \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0634\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0648 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 \u062f\u0631 \u0645\u062d\u0644 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f.<\/li>\n<li><strong>dragend:<\/strong> \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0647\u0646\u06af\u0627\u0645 \u06a9\u0634\u06cc\u062f\u0646 \u06cc\u06a9 \u0622\u06cc\u062a\u0645\u060c \u062f\u06a9\u0645\u0647 \u0645\u0627\u0648\u0633 \u0631\u0627 \u0631\u0647\u0627 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u062e \u0645\u06cc \u062f\u0647\u062f.<\/li>\n<\/ul>\n<h2 id=\"gettingstarted\"><span class=\"ez-toc-section\" id=\"%d8%b4%d8%b1%d9%88%d8%b9_%d8%b4%d8%af%d9%86\"><\/span>\u0634\u0631\u0648\u0639 \u0634\u062f\u0646<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u06a9\u067e\u06cc \u0633\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0628\u0631\u062f Trello \u0628\u0633\u0627\u0632\u06cc\u0645!  \u0646\u062a\u06cc\u062c\u0647 \u0686\u06cc\u0632\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u062e\u0637\u0648\u0637 \u0628\u0647 \u0646\u0638\u0631 \u0645\u06cc \u0631\u0633\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-1.png\" alt=\"\u06a9\u0644\u0648\u0646 \u062a\u062e\u062a\u0647 \u062a\u0631\u0644\u0648 \u06a9\u0627\u0646\u0628\u0627\u0646 \u0628\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648\u0627\u0646\u06cc\u0644\u06cc\" title=\"\"><\/p>\n<h3 id=\"creatingtheprojectandinitialmarkup\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d9%88%da%98%d9%87_%d9%88_%d9%86%d8%b4%d8%a7%d9%86%d9%87_%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%a7%d9%88%d9%84%db%8c%d9%87\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0648\u0698\u0647 \u0648 \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0633\u0627\u062e\u062a\u0627\u0631 \u0627\u0635\u0644\u06cc \u0631\u0627 \u062f\u0631 HTML \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 &#8211; a <code>container<\/code> \u0628\u0627 \u0686\u0646\u062f\u06cc\u0646 <code>column<\/code> \u0639\u0646\u0627\u0635\u0631\u06cc \u06a9\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0648\u0638\u0627\u06cc\u0641 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u0628\u06af\u0648\u06cc\u06cc\u062f\u060c \u0641\u0647\u0631\u0633\u062a \u0627\u0648\u0644\u060c \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 <em>&#8220;\u0647\u0645\u0647 \u0648\u0638\u0627\u06cc\u0641&#8221;<\/em> \u0633\u062a\u0648\u0646\u060c \u062f\u0631 \u0627\u0628\u062a\u062f\u0627 \u0647\u0645\u0647 \u0648\u0638\u0627\u06cc\u0641 \u0631\u0627 \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646\u200c\u0647\u0627 \u0631\u0627 \u0628\u06a9\u0634\u06cc\u0645 \u0648 \u0628\u0647 \u0633\u062a\u0648\u0646\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>All Tasks<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span>&gt;<\/span>Wash Clothes<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span>&gt;<\/span>Meeting at 9AM<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span>&gt;<\/span>Fix workshop<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span>&gt;<\/span>Visit the zoo<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>In progress<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Paused<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Under Review<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Completed<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0633\u0628\u06a9 \u0627\u0628\u062a\u062f\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>container<\/code>\u060c <code>column<\/code>\u0634\u0646 <code>item<\/code>s:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-selector-class\">.container<\/span>{\n    <span class=\"hljs-attribute\">font-family<\/span>: <span class=\"hljs-string\">\"Trebuchet MS\"<\/span>, sans-serif;\n    <span class=\"hljs-attribute\">display<\/span>: flex;\n    gap: <span class=\"hljs-number\">30px<\/span>;\n}\n<span class=\"hljs-selector-class\">.column<\/span>{\n    <span class=\"hljs-attribute\">flex-basis<\/span>: <span class=\"hljs-number\">20%<\/span>;\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#ddd<\/span>;\n    <span class=\"hljs-attribute\">min-height<\/span>: <span class=\"hljs-number\">90vh<\/span>;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">20px<\/span>;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">10px<\/span>;\n}\n<span class=\"hljs-selector-class\">.column<\/span> <span class=\"hljs-selector-tag\">h1<\/span>{\n    <span class=\"hljs-attribute\">text-align<\/span>: center;\n    <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">22px<\/span>;\n}\n<span class=\"hljs-selector-class\">.item<\/span>{\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#fff<\/span>;\n    <span class=\"hljs-attribute\">margin<\/span>: <span class=\"hljs-number\">20px<\/span>;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">20px<\/span>;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">3px<\/span>;\n    <span class=\"hljs-attribute\">cursor<\/span>: pointer;\n}\n<span class=\"hljs-selector-class\">.invisible<\/span>{\n    <span class=\"hljs-attribute\">display<\/span>: none;\n}\n<\/code><\/pre>\n<p>\u0631\u0627 page \u0628\u0627\u06cc\u062f \u0686\u06cc\u0632\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0633\u062a\u0627 \u0646\u06af\u0627\u0647 \u06a9\u0631\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-1.png\" alt=\"\u0628\u0631\u062f \u06a9\u0627\u0646\u0628\u0627\u0646 \u0648\u0627\u0646\u06cc\u0644\u06cc \u062c\u06cc \u0627\u0633\" title=\"\"><\/p>\n<h4 id=\"makinganobjectdraggable\">\u0633\u0627\u062e\u062a \u06cc\u06a9 \u0634\u06cc\u0621 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646<\/h4>\n<p>\u0627\u06af\u0631\u0686\u0647 \u0627\u06cc\u0646 \u0627\u0634\u06cc\u0627\u0621 \u0647\u0646\u0648\u0632 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0646\u06cc\u0633\u062a\u0646\u062f.  \u0622\u0646\u0647\u0627 \u0641\u0642\u0637 \u0622\u0646\u062c\u0627 \u0647\u0633\u062a\u0646\u062f!  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0634\u06cc \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0628\u0627\u0634\u062f &#8211; \u0622\u0646 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>draggable<\/code> \u0646\u0633\u0628\u062a \u0628\u0647 <code>true<\/code>.  \u0647\u0631 \u0686\u06cc\u0632\u06cc \u0631\u0648\u06cc \u0648\u0628 \u0633\u0627\u06cc\u062a \u0634\u0645\u0627\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0639\u06a9\u0633 \u0647\u0627\u060c \u0641\u0627\u06cc\u0644 \u0647\u0627\u060c \u0644\u06cc\u0646\u06a9 \u0647\u0627 \u0648 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u062f\u0631\u06af \u06a9\u0631\u062f!<\/p>\n<p>\u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 <code>draggable=\"true\"<\/code> \u0631\u0648\u06cc  \u0645\u0627 <code>item<\/code> \u0639\u0646\u0627\u0635\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>All Tasks<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Wash Clothes<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Meeting at 9AM<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Fix workshop<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Visit the zoo<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06a9\u0647 \u0639\u0646\u0627\u0635\u0631 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0647\u0633\u062a\u0646\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u06a9\u0634\u06cc\u062f\u0646 \u0631\u0627 \u0645\u0646\u062a\u0634\u0631 \u06a9\u0646\u0646\u062f!  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0634\u0646\u0648\u0646\u062f\u06af\u0627\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u0646\u062f \u0648 \u0628\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0648\u0627\u06a9\u0646\u0634 \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f.<\/p>\n<h3 id=\"handlingdraganddropeventswithjavascript\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af%d9%87%d8%a7%db%8c_drag-and-drop_%d8%a8%d8%a7_%d8%ac%d8%a7%d9%88%d8%a7_%d8%a7%d8%b3%da%a9%d8%b1%db%8c%d9%be%d8%aa\"><\/span>\u0645\u062f\u06cc\u0631\u06cc\u062a \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc Drag-and-Drop \u0628\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0647\u0645\u0647 \u0645\u0648\u0627\u0631\u062f \u0648 \u0633\u062a\u0648\u0646 \u0647\u0627 \u0631\u0627 \u062c\u0645\u0639 \u0622\u0648\u0631\u06cc \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>document.querySelectorAll()<\/code> \u0627\u0646\u062a\u062e\u0627\u0628\u06af\u0631\u0647\u0627\u06cc DOM!  \u0627\u06cc\u0646 \u06cc\u06a9 \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062e\u0648\u0627\u0647\u062f \u062f\u0627\u0634\u062a <code>NodeList<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0622\u0646 \u062d\u0644\u0642\u0647 \u0628\u0632\u0646\u06cc\u0645 \u062a\u0627 \u0628\u0627 \u0647\u0631 \u0622\u06cc\u062a\u0645\/\u0633\u062a\u0648\u0646 \u0645\u062c\u0632\u0627 \u06a9\u0627\u0631 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> items = <span class=\"hljs-built_in\">document<\/span>.querySelectorAll(<span class=\"hljs-string\">'.item'<\/span>)\n<span class=\"hljs-keyword\">const<\/span> columns = <span class=\"hljs-built_in\">document<\/span>.querySelectorAll(<span class=\"hljs-string\">'.column'<\/span>)\n<\/code><\/pre>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u0637\u0628\u06cc\u0639\u06cc &#8211; \u0627\u06af\u0631 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0645\u0648\u0627\u0631\u062f \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0646\u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f!<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0639\u0646\u0627\u0635\u0631 \u0631\u0627 \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u0645 \u0648 \u0628\u0647 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u06cc\u06a9 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645.  \u06cc\u06a9 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0631\u0627\u06cc \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>dragstart<\/code> \u0648 <code>dragend<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0648 \u062a\u0648\u0627\u0628\u0639\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0647\u0646\u06af\u0627\u0645 \u0627\u062c\u0631\u0627 \u0627\u062c\u0631\u0627 \u0634\u0648\u0646\u062f:<\/p>\n<pre><code class=\"hljs\">items.forEach(<span class=\"hljs-function\"><span class=\"hljs-params\">item<\/span> =&gt;<\/span> {\n    item.addEventListener(<span class=\"hljs-string\">'dragstart'<\/span>, dragStart)\n    item.addEventListener(<span class=\"hljs-string\">'dragend'<\/span>, dragEnd)\n});\n<\/code><\/pre>\n<p><code>dragStart()<\/code>  \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f \u0631\u0648\u06cc \u0647\u0631 \u06cc\u06a9 <code>'dragstart'<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f\u060c \u0648 <code>dragEnd()<\/code> \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f \u0631\u0648\u06cc \u0647\u0631 \u06cc\u06a9 <code>'dragend'<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f.<\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0627\u0632 \u0627\u06cc\u0646 \u062a\u0648\u0627\u0628\u0639 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 \u06cc\u06a9 \u0638\u0627\u0647\u0631 \u0637\u0631\u0627\u062d\u06cc \u0628\u0631\u0627\u06cc \u062a\u0639\u0627\u0645\u0644 \u0628\u0635\u0631\u06cc \u0628\u0647\u062a\u0631 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u062e\u0627\u0635 \u0631\u0627 \u0645\u06cc \u06a9\u0634\u0646\u062f \u0648 \u0631\u0647\u0627 \u0645\u06cc \u06a9\u0646\u0646\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0635\u0627\u0641 \u06a9\u0627\u0631\u062a\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u062c\u0627\u0628\u062c\u0627\u06cc\u06cc \u0647\u0633\u062a\u06cc\u062f\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0639\u0645\u0644\u06a9\u0631\u062f \u0631\u0627 \u0641\u0642\u0637 \u0628\u0627 \u0648\u0631\u0648\u062f \u0628\u0647 \u0633\u06cc\u0633\u062a\u0645 \u067e\u06cc\u0627\u0645 \u0647\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragStart<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag started'<\/span>);\n}\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragEnd<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag ended'<\/span>);\n}\n<\/code><\/pre>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-2.gif\" alt=\"\u0639\u0646\u0627\u0635\u0631 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0628\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\" title=\"\"><\/p>\n<p>\u0639\u0627\u0644\u06cc!  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0628\u0647 \u0627\u0637\u0631\u0627\u0641 \u06a9\u0634\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f &#8211; \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0634\u0644\u06cc\u06a9 \u0647\u0633\u062a\u0646\u062f.  \u0627\u06a9\u0646\u0648\u0646\u060c \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0641\u0642\u0637 \u067e\u06cc\u0627\u0645 \u0631\u0627 \u062b\u0628\u062a \u06a9\u0646\u06cc\u0645\u060c \u0628\u0647 \u062c\u0627\u06cc \u0622\u0646 \u0646\u0627\u0645 \u06a9\u0644\u0627\u0633 \u0631\u0627 \u0631\u0648\u06cc \u06a9\u0627\u0631\u062a \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u0645.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0627 \u0646\u0627\u0645\u0631\u0626\u06cc \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0631\u062a \u0645\u0646\u062a\u0642\u0644 \u0634\u062f\u0647 \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0627\u0632 \u0644\u06cc\u0633\u062a \u0627\u0635\u0644\u06cc \u0645\u062d\u0648 \u0634\u0648\u062f.  \u0645\u0627 \u0628\u0647 \u0639\u0646\u0635\u0631 \u06a9\u0634\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a\u0627\u06cc\u0644 \u0645\u06cc \u062f\u0647\u06cc\u0645 \u0648 \u0645\u0646\u0637\u0642 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u06a9\u0645\u06cc \u0628\u0639\u062f \u062f\u0631 \u0644\u06cc\u0633\u062a \u062c\u062f\u06cc\u062f\u06cc \u0638\u0627\u0647\u0631 \u0634\u0648\u062f.<\/p>\n<p>\u0644\u0627\u0632\u0645 \u0646\u06cc\u0633\u062a \u0639\u0646\u0635\u0631 \u0646\u0627\u067e\u062f\u06cc\u062f \u0634\u0648\u062f.  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u062f\u0648\u0631\u062a \u0622\u0646 \u0631\u0627 \u0645\u062d\u0648 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0646\u0634\u0627\u0646 \u062f\u0647\u06cc\u062f \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u0645\u06a9\u0627\u0646 \u0628\u0647 \u0645\u06a9\u0627\u0646 \u062f\u06cc\u06af\u0631 \u06a9\u0634\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0627 \u062e\u06cc\u0627\u0644 \u0631\u0627\u062d\u062a \u062e\u0644\u0627\u0642 \u0634\u0648\u06cc\u062f!<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0627\u0635\u0644\u0627\u062d \u06a9\u0646\u06cc\u0645 <code>dragStart()<\/code> \u062a\u0627\u0628\u0639:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragStart<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag started'<\/span>);\n    <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> <span class=\"hljs-built_in\">this<\/span>.className = <span class=\"hljs-string\">'invisible'<\/span>, <span class=\"hljs-number\">0<\/span>)\n}\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 &#8211; \u0645\u0627 \u0641\u0642\u0637 \u0628\u0627 \u06a9\u0627\u0631\u062a \u0647\u0627 \u062a\u0639\u0627\u0645\u0644 \u0646\u062f\u0627\u0631\u06cc\u0645.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0627 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u062a\u0639\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <em>\u0633\u062a\u0648\u0646<\/em> \u0628\u0631\u0627\u06cc \u067e\u0630\u06cc\u0631\u0634 \u06a9\u0627\u0631\u062a \u062c\u062f\u06cc\u062f \u0648 \u062d\u0630\u0641 \u06a9\u0627\u0631\u062a \u0647\u0627 \u0627\u0632 \u0633\u062a\u0648\u0646 \u0647\u0627\u06cc \u0642\u062f\u06cc\u0645\u06cc.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0645\u062a\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u062f\u0631 \u0647\u0646\u06af\u0627\u0645 \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0633\u062a\u0648\u0646 \u0647\u0627 \u0622\u062a\u0634 \u0645\u06cc \u06af\u06cc\u0631\u0646\u062f\u060c \u062f\u0631\u0633\u062a \u0645\u0627\u0646\u0646\u062f \u0645\u0648\u0627\u0631\u062f!<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u0645 \u0648 \u0634\u0646\u0648\u0646\u062f\u06af\u0627\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>columns<\/code>:<\/p>\n<pre><code class=\"hljs\">columns.forEach(<span class=\"hljs-function\"><span class=\"hljs-params\">column<\/span> =&gt;<\/span> {\n    column.addEventListener(<span class=\"hljs-string\">'dragover'<\/span>, dragOver);\n    column.addEventListener(<span class=\"hljs-string\">'dragenter'<\/span>, dragEnter);\n    column.addEventListener(<span class=\"hljs-string\">'dragleave'<\/span>, dragLeave);\n    column.addEventListener(<span class=\"hljs-string\">'drop'<\/span>, dragDrop);\n});\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0634\u0646\u0648\u0646\u062f\u06af\u0627\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u0631\u0627 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragOver<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag over'<\/span>);\n}\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragEnter<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag entered'<\/span>);\n}\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragLeave<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag left'<\/span>);\n}\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragDrop<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag dropped'<\/span>);\n}\n<\/code><\/pre>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u062e\u0648\u062f \u0645\u0634\u0627\u0647\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0648\u0627\u0631\u062f \u0631\u0627 \u062f\u0631\u06af \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u0646\u0627\u067e\u062f\u06cc\u062f \u0634\u0648\u0646\u062f \u0648 console \u0647\u0646\u06af\u0627\u0645 \u0639\u0628\u0648\u0631 \u0627\u0632 \u06cc\u06a9 \u0633\u062a\u0648\u0646 \u062c\u062f\u06cc\u062f \u0628\u0627 \u0622\u06cc\u062a\u0645\u060c \u0644\u0627\u06af \u0647\u0627 \u0628\u0627\u06cc\u062f \u0638\u0627\u0647\u0631 \u0634\u0648\u0646\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-3.gif\" alt=\"\u06a9\u0634\u06cc\u062f\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\" title=\"\"><\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0627\u06af\u0631 \u0628\u0647 \u062f\u0642\u062a \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f console \u0645\u0646\u0637\u0642\u0647\u060c \u0634\u0645\u0627 \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 <code>dragDrop()<\/code> \u0645\u062a\u062f \u067e\u06cc\u0627\u0645\u06cc \u0631\u0627 \u062b\u0628\u062a \u0646\u06a9\u0631\u062f.  \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0628\u0627\u06cc\u062f \u0631\u0641\u062a\u0627\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0631\u0627 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f <code>dragOver()<\/code> \u0631\u0648\u0634.<\/p>\n<\/p><\/div><\/div><\/div>\n<pre><code class=\"hljs\"><span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragOver<\/span>(<span class=\"hljs-params\">e<\/span>) <\/span>{\n  e.preventDefault()\n  <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag over'<\/span>);\n}\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c \u0648\u0642\u062a\u06cc \u0645\u0648\u0631\u062f \u0631\u0627 \u0631\u0647\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 &#8220;\u06a9\u0634\u06cc\u062f\u0646 \u0631\u0647\u0627 \u0634\u062f&#8221; \u062b\u0628\u062a \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06cc\u0646\u0647\u0627 \u062a\u0645\u0627\u0645 \u0627\u062a\u0641\u0627\u0642\u0627\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0647 \u0622\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645!  \u0627\u06a9\u0646\u0648\u0646\u060c \u0645\u0627 \u0641\u0642\u0637 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u0645\u0646\u0637\u0642 \u062d\u0630\u0641 \u0622\u06cc\u062a\u0645\u200c\u0647\u0627\u060c \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0622\u0646\u200c\u0647\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646\u200c\u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631 \u0635\u0648\u0631\u062a \u062d\u0630\u0641 \u0634\u062f\u0646\u060c \u0648 \u063a\u06cc\u0631\u0647 \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u0622\u06cc\u062a\u0645 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u062f\u0631 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u0627\u0632 \u0632\u0645\u0627\u0646 \u06a9\u0634\u06cc\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u06cc\u0645\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0633\u0631\u0627\u0633\u0631\u06cc \u0628\u0631\u0627\u06cc \u0622\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.  \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0645\u0631\u062c\u0639 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u062f\u0647\u06cc\u0645\u060c \u06cc\u06a9 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f <code>let<\/code>\u060c \u0646\u0647 a <code>const<\/code>.<\/p>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0634\u06cc\u062f\u0646 \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u062f &#8211; \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>this<\/code> \u0639\u0646\u0635\u0631 \u0628\u0647 <code>dragItem<\/code>\u060c \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0633\u062a\u0648\u0646\u06cc \u06a9\u0647 \u0628\u0647 \u0622\u0646 \u0631\u0647\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0631\u0648\u06cc \u0622\u0646 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>null<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">let<\/span> dragItem = <span class=\"hljs-literal\">null<\/span>;\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragStart<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag started'<\/span>);\n    dragItem = <span class=\"hljs-built_in\">this<\/span>;\n    <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> <span class=\"hljs-built_in\">this<\/span>.className = <span class=\"hljs-string\">'invisible'<\/span>, <span class=\"hljs-number\">0<\/span>)\n}\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragEnd<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag ended'<\/span>);\n      <span class=\"hljs-built_in\">this<\/span>.className = <span class=\"hljs-string\">'item'<\/span>\n      dragItem = <span class=\"hljs-literal\">null<\/span>;\n}\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">dragDrop<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n    <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'drag dropped'<\/span>);\n    <span class=\"hljs-built_in\">this<\/span>.append(dragItem);\n}\n<\/code><\/pre>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0647\u0631 \u0639\u0646\u0635\u0631\u06cc \u06a9\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0631\u0627 \u0633\u0627\u0637\u0639 \u0645\u06cc \u06a9\u0646\u062f \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 <code>this<\/code> \u06a9\u0644\u0645\u0647 \u06a9\u0644\u06cc\u062f\u06cc\u060c \u062f\u0631 \u0645\u062a\u062f \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0634\u062f\u0647 \u0647\u0646\u06af\u0627\u0645 \u0627\u062c\u0631\u0627 \u0634\u062f\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0647\u0645\u06cc\u0646 &#8211; \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u06a9\u0627\u0631\u062a \u0647\u0627 \u0631\u0627 \u0627\u0632 \u06cc\u06a9 \u0633\u062a\u0648\u0646 \u0628\u0647 \u0633\u062a\u0648\u0646 \u062f\u06cc\u06af\u0631 \u0628\u06a9\u0634\u06cc\u0645 \u0648 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-4.gif\" alt=\"\u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648\u0627\u0646\u06cc\u0644\u06cc \u0628\u06a9\u0634\u06cc\u062f \u0648 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u062f\" title=\"\"><\/p>\n<p>\u0645\u0627 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0647\u0645\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0646\u062f\u0627\u0631\u06cc\u0645 &#8211; \u0622\u0646\u0647\u0627 \u0627\u0636\u0627\u0641\u0647 \u0634\u062f\u0647 \u0627\u0646\u062f \u0648 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0631\u0627\u06cc \u0633\u0628\u06a9 \u0633\u0627\u0632\u06cc \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0642\u0631\u0627\u0631 \u06af\u06cc\u0631\u0646\u062f. process.<\/p>\n<p>\u0646\u06a9\u062a\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0622\u0646 \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0647 \u062a\u0631\u062a\u06cc\u0628 \u0639\u0646\u0627\u0635\u0631 \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <em>\u067e\u0627\u06cc\u0627\u0646<\/em> \u0627\u0632 \u0647\u0631 \u0633\u062a\u0648\u0646\u060c \u0647\u0645\u06cc\u0634\u0647\u060c \u0632\u06cc\u0631\u0627 \u0645\u0627 \u0645\u0648\u0642\u0639\u06cc\u062a \u0646\u0633\u0628\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u067e\u06cc\u06af\u06cc\u0631\u06cc \u0646\u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0641\u0642\u0637 \u062a\u0645\u0627\u0633 \u0645\u06cc \u06af\u06cc\u0631\u06cc\u0645 <code>append()<\/code> \u0648\u0642\u062a\u06cc \u0644\u0627\u0632\u0645 \u0628\u0627\u0634\u0647.  \u0627\u06cc\u0646 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0628\u0627 <em>\u0642\u0627\u0628\u0644 \u0645\u0631\u062a\u0628 \u0633\u0627\u0632\u06cc<\/em> \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647!<\/p>\n<h3 id=\"implementingdraganddropusingsortablejs\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_drag_and_drop_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_sortablejs\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc Drag and Drop \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 SortableJS<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>Sortable \u06cc\u06a9 \u0645\u0627\u0698\u0648\u0644 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0633\u0628\u06a9 \u0648 \u0633\u0627\u062f\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 API \u0627\u0635\u0644\u06cc HTML5 drag and drop \u0628\u0631\u0627\u06cc \u0645\u0631\u062a\u0628 \u06a9\u0631\u062f\u0646 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0627\u0634\u06cc\u0627\u0621 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f\u060c \u062f\u0631\u0633\u062a \u0645\u062b\u0644 \u0645\u0627!  \u0628\u0627 \u062a\u0645\u0627\u0645 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0648 \u062f\u0633\u062a\u06af\u0627\u0647 \u0647\u0627\u06cc \u0644\u0645\u0633\u06cc \u0645\u0639\u0627\u0635\u0631 \u0633\u0627\u0632\u06af\u0627\u0631 \u0627\u0633\u062a.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0645\u0631\u062a\u0628 \u06a9\u0631\u062f\u0646 \u0639\u0646\u0627\u0635\u0631 \u0639\u0627\u0644\u06cc \u0627\u0633\u062a <em>\u062f\u0631 \u062f\u0627\u062e\u0644<\/em> \u06cc\u06a9 \u0644\u06cc\u0633\u062a \u0648 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0639\u0646\u0627\u0635\u0631 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0633\u062a\u0648\u0646\u060c \u062f\u0631 \u0645\u0648\u0642\u0639\u06cc\u062a \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0628\u06a9\u0634\u06cc\u062f \u0648 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u062f\u060c \u0646\u0647 \u0641\u0642\u0637 \u0628\u06cc\u0646 \u0633\u062a\u0648\u0646 \u0647\u0627.  \u0627\u06cc\u0646 \u06cc\u06a9 \u0627\u0641\u0632\u0648\u0646\u0647 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f!<\/p>\n<p>\u062f\u0631 \u0648\u0627\u0642\u0639 &#8211; \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Sortable\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u06a9\u0644 \u0631\u0627 \u06a9\u0627\u0645\u0644\u0627\u064b \u062e\u0648\u062f\u06a9\u0627\u0631 \u06a9\u0646\u06cc\u0645 process \u0628\u0627 \u062f\u0627\u0634\u062a\u0646 \u06cc\u06a9 <em>\u06af\u0631\u0648\u0647<\/em> \u0627\u0632 \u0633\u062a\u0648\u0646 \u0647\u0627\u060c \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0645\u0648\u0627\u0631\u062f \u0631\u0627 \u0628\u0647 \u0627\u0634\u062a\u0631\u0627\u06a9 \u0628\u06af\u0630\u0627\u0631\u0646\u062f.<\/p>\n<p>\u0645\u0631\u062a\u0628 \u0633\u0627\u0632\u06cc \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0627\u0632 \u0637\u0631\u06cc\u0642 CDN \u0648\u0627\u0631\u062f \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"hljs\">&lt;script src=<span class=\"hljs-string\">\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/Sortable\/1.14.0\/Sortable.min.js\"<\/span> integrity=<span class=\"hljs-string\">\"sha512-zYXldzJsDrNKV+odAwFYiDXV2Cy37cwizT+NkuiPGsa9X1dOz04eHvUWVuxaJ299GvcJT31ug2zO4itXBjFx4w==\"<\/span> crossorigin=<span class=\"hljs-string\">\"anonymous\"<\/span> referrerpolicy=<span class=\"hljs-string\">\"no-referrer\"<\/span>&gt;&lt;\/script&gt;\n<\/code><\/pre>\n<p>\u06cc\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 NPM \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install sortablejs --save<\/span>\n<\/code><\/pre>\n<p>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Sortable \u0628\u0647 \u0622\u0633\u0627\u0646\u06cc \u0646\u0645\u0648\u0646\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0627\u0633\u062a <code>Sortable<\/code> \u0647\u062f\u0641 &#8211; \u0634\u06cc\u060c \u0631\u0648\u06cc \u06cc\u06a9 \u0639\u0646\u0635\u0631 HTML \u062f\u0627\u062f\u0647 \u0634\u062f\u0647:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> column = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'.column'<\/span>);\n\n<span class=\"hljs-keyword\">new<\/span> Sortable(column, {\n    <span class=\"hljs-attr\">animation<\/span>: <span class=\"hljs-number\">150<\/span>,\n    <span class=\"hljs-attr\">ghostClass<\/span>: <span class=\"hljs-string\">'blue-background-class'<\/span>\n});\n<\/code><\/pre>\n<p>\u0645\u0642\u062f\u0627\u0631 \u0645\u0646\u0627\u0633\u0628\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u06a9\u0631\u062f\u0646 \u0622\u0646\u0647\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f process &#8211; \u062f\u0648 \u0645\u0648\u0631\u062f \u0627\u0632 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.  \u0631\u0627 <code>animation<\/code> \u0632\u0645\u0627\u0646 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0645\u06cc\u0644\u06cc \u062b\u0627\u0646\u06cc\u0647 \u0628\u06cc\u0627\u0646 \u0645\u06cc \u0634\u0648\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 <code>ghostClass<\/code> \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u062a\u0644\u0637\u06cc\u0641 \u0686\u06af\u0648\u0646\u06af\u06cc \u0638\u0627\u0647\u0631 &#8220;\u0634\u0628\u062d&#8221; \u0639\u0646\u0635\u0631 \u06a9\u0634\u06cc\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f!  \u0627\u06cc\u0646 \u0628\u0627\u0639\u062b \u0645\u06cc \u0634\u0648\u062f \u062a\u0627 \u062a\u062c\u0631\u0628\u0647 \u0628\u0633\u06cc\u0627\u0631 \u0628\u0647\u062a\u0631\u06cc \u0627\u0632 \u06a9\u0634\u06cc\u062f\u0646 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0645\u062b\u0627\u0644 Trello \u062e\u0648\u062f \u0628\u0631\u06af\u0631\u062f\u06cc\u0645 \u0648 Sortable \u0631\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u0645!  \u0645\u0627 \u0631\u0627 \u0645\u0644\u0632\u0645 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>list-group-item<\/code> \u06a9\u0644\u0627\u0633 \u0628\u0647 \u062c\u0627\u06cc <code>item<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>All Tasks<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Wash Clothes<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Take a stroll outside<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Design Thumbnail<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Attend Meeting<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Fix workshop<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"list-group-item\"<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span>Visit the zoo<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>In progress<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Paused<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Under Review<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"column\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Completed<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0647\u0645\u0627\u0646 \u0633\u0628\u06a9 \u0642\u0628\u0644\u06cc \u0631\u0627 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-selector-class\">.container<\/span> {\n    <span class=\"hljs-attribute\">font-family<\/span>: <span class=\"hljs-string\">\"Trebuchet MS\"<\/span>, sans-serif;\n    <span class=\"hljs-attribute\">display<\/span>: flex;\n    gap: <span class=\"hljs-number\">30px<\/span>;\n}\n<span class=\"hljs-selector-class\">.column<\/span> {\n    <span class=\"hljs-attribute\">flex-basis<\/span>: <span class=\"hljs-number\">20%<\/span>;\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#ddd<\/span>;\n    <span class=\"hljs-attribute\">min-height<\/span>: <span class=\"hljs-number\">90vh<\/span>;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">5px<\/span>;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">10px<\/span>;\n}\n<span class=\"hljs-selector-class\">.column<\/span> <span class=\"hljs-selector-tag\">h1<\/span> {\n    <span class=\"hljs-attribute\">text-align<\/span>: center;\n    <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">22px<\/span>;\n}\n<span class=\"hljs-selector-class\">.list-group-item<\/span> {\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#fff<\/span>;\n    <span class=\"hljs-attribute\">margin<\/span>: <span class=\"hljs-number\">20px<\/span>;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">20px<\/span>;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">5px<\/span>;\n    <span class=\"hljs-attribute\">cursor<\/span>: pointer;\n}\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f a \u0631\u0627 \u0646\u0645\u0648\u0646\u0647 \u06a9\u0646\u06cc\u0645 <code>Sortable<\/code> \u0628\u0631\u0627\u06cc \u0647\u0631 \u0633\u062a\u0648\u0646 \u0631\u0648\u06cc \u0631\u0627 page\u060c \u062a\u0646\u0638\u06cc\u0645 \u0622\u0646\u0647\u0627 <code>group<\/code> \u0628\u0647 <code>\"shared\"<\/code> \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u06a9\u0627\u0631\u062a \u0647\u0627 \u0628\u06cc\u0646 \u0633\u062a\u0648\u0646 \u0647\u0627 \u0642\u0627\u0628\u0644 \u0627\u0634\u062a\u0631\u0627\u06a9 \u06af\u0630\u0627\u0631\u06cc \u0647\u0633\u062a\u0646\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> columns = <span class=\"hljs-built_in\">document<\/span>.querySelectorAll(<span class=\"hljs-string\">\".column\"<\/span>);\n\ncolumns.forEach(<span class=\"hljs-function\">(<span class=\"hljs-params\">column<\/span>) =&gt;<\/span> {\n    <span class=\"hljs-keyword\">new<\/span> Sortable(column, {\n        <span class=\"hljs-attr\">group<\/span>: <span class=\"hljs-string\">\"shared\"<\/span>,\n        <span class=\"hljs-attr\">animation<\/span>: <span class=\"hljs-number\">150<\/span>,\n        <span class=\"hljs-attr\">ghostClass<\/span>: <span class=\"hljs-string\">\"blue-background-class\"<\/span>\n    });\n});\n<\/code><\/pre>\n<p>\u062e\u0648\u062f\u0634\u0647!  Sortable \u0627\u0632 \u0628\u0642\u06cc\u0647 \u0645\u0648\u0627\u0631\u062f \u0645\u0631\u0627\u0642\u0628\u062a \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/drag-and-drop-in-vanilla-javascript-5.gif\" alt=\"\u0628\u0627 sortableJS \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u06a9\u0634\u06cc\u062f \u0648 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u062f\" title=\"\"><\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0639\u0646\u0627\u0635\u0631 \u062f\u0631 HTML5 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0642\u0627\u0628\u0644 \u0645\u0631\u062a\u0628\u200c\u0633\u0627\u0632\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0646\u062f\u0627\u062e\u062a\u0647\u200c\u0627\u06cc\u0645.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-11 15:48:08<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;15378&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a Vanilla \u0639\u0645\u0644 \u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0622\u06cc\u062a\u0645 \u06cc\u0627 \u062a\u06a9\u0647\u200c\u0627\u06cc \u0627\u0632 \u0645\u062a\u0646\u060c \u062c\u0627\u0628\u062c\u0627\u06cc\u06cc \u0622\u0646 (\u06a9\u0634\u06cc\u062f\u0646) \u0648 \u0633\u067e\u0633 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 (\u0631\u0647\u0627 \u06a9\u0631\u062f\u0646) \u062f\u0631 \u0645\u06a9\u0627\u0646\u06cc \u062f\u06cc\u06af\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.  \u0627\u06a9\u062b\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u062a\u0646\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u0628\u0631\u0627\u06cc \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u062a\u0635\u0627\u0648\u06cc\u0631 \u06cc\u0627 \u0646\u0634\u0627\u0646\u200c\u0648\u0627\u0631\u0647\u200c\u0647\u0627\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u062a\u0635\u0648\u06cc\u0631 \u0631\u0627 \u0628\u06a9\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 ...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 8<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0639\u0645\u0644 \u0627\u0646\u062a\u062e\u0627\u0628 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u06cc\u0627 \u062a\u06a9\u0647 \u0627\u06cc \u0627\u0632 \u0645\u062a\u0646\u060c \u062c\u0627\u0628\u062c\u0627\u06cc\u06cc \u0622\u0646 (\u06a9\u0634\u06cc\u062f\u0646) \u0648 \u0633\u067e\u0633 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646 (\u0627\u0646\u062f\u0627\u062e\u062a\u0646) \u062f\u0631 \u0645\u06a9\u0627\u0646 \u062f\u06cc\u06af\u0631\u06cc \u062a\u0648\u0635\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0642\u0627\u0628\u0644\u06cc\u062a \u06a9\u0634\u06cc\u062f\u0646 \u0648 \u0631\u0647\u0627 \u06a9\u0631\u062f\u0646. \u0627\u06a9\u062b\u0631 \u0645\u0631\u0648\u0631\u06af\u0631\u0647\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u062a\u0646\u060c \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0642\u0627\u0628\u0644 \u06a9\u0634\u06cc\u062f\u0646 \u0645\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u060c [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15379,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[1828,1100,3357,1252,1964,1844,2341,1904,2488,1776,1781,3351,2433,2242,1986,1814,3778,1807,1825,3885,3326,3763,3880,3881,1780,2416,2750,3555,1803,3779,2667,3751,3568,2820,3545,1808,1826,3270,3883,2415,1892,3761,2425,1985,2293,1809,3385,3882,1790,3884,3886,1966,2323,2250,1818,1831,1813],"class_list":{"0":"post-15378","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","6":"hentry","7":"category-javascript","8":"category-programming","9":"tag-1828","10":"tag-javascript","11":"tag-vanilla","12":"tag--nodejs","13":"tag----frontend","14":"tag-1844","15":"tag-2341","16":"tag-1904","17":"tag-2488","18":"tag-1776","19":"tag-1781","20":"tag-3351","21":"tag-2433","22":"tag-2242","23":"tag-1986","24":"tag-1814","25":"tag-3778","26":"tag-1807","27":"tag-1825","28":"tag-3885","29":"tag-3326","30":"tag-3763","31":"tag-3880","32":"tag-3881","33":"tag-1780","34":"tag-2416","35":"tag-2750","36":"tag-3555","37":"tag-1803","38":"tag-3779","39":"tag-2667","40":"tag-3751","41":"tag-3568","42":"tag-2820","43":"tag-3545","44":"tag-1808","45":"tag-1826","46":"tag-3270","47":"tag-3883","48":"tag-2415","49":"tag-1892","50":"tag-3761","51":"tag-2425","52":"tag-1985","53":"tag-2293","54":"tag-1809","55":"tag-3385","56":"tag-3882","57":"tag-1790","58":"tag-3884","59":"tag-3886","60":"tag--javascrip","61":"tag--node","63":"tag-1818","64":"tag-1831","65":"tag-1813"},"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15378","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=15378"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15378\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15379"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15378"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15378"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15378"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}