MooTools - खींचें और ड्रॉप

MooTools एक जबरदस्त सुविधा प्रदान करता है जो आपको ड्रैग फ़ंक्शंस जोड़ने और अपने वेब पेज तत्वों को ड्रैग फ़ंक्शंस छोड़ने में मदद करता है। हम अपने स्वयं के नए बनाकर ऐसा कर सकते हैंDrag.Moveवस्तु। इस ऑब्जेक्ट का उपयोग करके, आप अपने विकल्पों और घटनाओं को परिभाषित कर सकते हैं। ड्रैग और ड्रैग करें। चूहे वर्ग MooTools More पुस्तकालय से हैं।

ड्रैग.ओव ऑब्जेक्ट के विकल्पों और घटनाओं पर चर्चा करते हैं।

Drag.Move

ड्रैग.मूव एक ऐसी वस्तु है जिसका इस्तेमाल ड्रैग एंड ड्रॉप फीचर को html एलिमेंट्स में जोड़ने के लिए किया जाता है। Drag.Move ड्रैग को बढ़ाता है, इसलिए हम Drag.Move ऑब्जेक्ट द्वारा ड्रैग क्लास के सभी विकल्पों और घटनाओं का उपयोग कर सकते हैं। निम्नलिखित सिंटैक्स पर एक नज़र डालें और समझें कि ड्रैग.वॉव ऑब्जेक्ट का उपयोग कैसे करें।

वाक्य - विन्यास

var myDrag = new Drag.Move(dragElement, {
   // Drag.Move Options
   droppables: dropElement,
   container: dragContainer,
   
   // Drag Options
   handle: dragHandle,

   // Drag.Move Events
   // the Drag.Move events pass the dragged element,
   // and the dropped into droppable element
   onDrop: function(el, dr) {
      //will alert the id of the dropped into droppable element
      alert(dr.get('id'));
   },
   // Drag Events
   // Drag events pass the dragged element
   onComplete: function(el) {
      alert(el.get('id'));
   }
});

विकल्प खींचें

Drag.Move खींचें और ड्रॉप सुविधाओं के साथ HTML तत्वों को बनाए रखने के लिए निम्नलिखित विकल्प प्रदान करता है -

  • droppable - यह आपको ड्रापेबल तत्वों (ड्रॉप-संबंधित घटनाओं पर पंजीकरण करने वाले तत्वों) के चयनकर्ता को सेट करने में मदद करता है।

  • container - यह आपको ड्रैग एलिमेंट के कंटेनर को सेट करने में मदद करता है (एलिमेंट को अंदर रखता है)।

  • snap- इससे आपको यह निर्धारित करने में मदद मिलती है कि ड्रैग करने योग्य तत्व को खींचने से पहले उपयोगकर्ता को कितने पीएक्स को खींचना चाहिए। डिफ़ॉल्ट 6 है, और आप इसे संख्या के किसी भी चर को निर्धारित कर सकते हैं।

  • handle- यह आपको अपने ड्रैग करने योग्य तत्व के लिए एक हैंडल जोड़ने में मदद करता है। हैंडल एकमात्र तत्व बन जाता है जो हड़पने को स्वीकार करेगा।

ड्रापेबल और कंटेनर, स्नैप, और हैंडल तत्वों को कैसे और कहां परिभाषित करना है, इसके लिए निम्नलिखित सिंटैक्स पर एक नज़र डालें।

वाक्य - विन्यास

//here we define a single element by id
var dragElement = $('drag_element');

//here we define an array of elements by class
var dropElements = $$('.drag_element');
var dragContainer = $('drag_container');
var dragHandle = $('drag_handle');

//now we set up our Drag.Move object
var myDrag = new Drag.Move(dragElement , {
   // Drag.Move Options
   // set up our droppables element with the droppables var we defined above
   droppables: dropElements ,
   
   // set up our container element with the container element var
   container: dragContainer
   
   // set up pixels the user must drag.
   Snap: 10
   
   // Adds a handle to your draggable element
   handle: dragHandle
});

घटनाओं को खींचें

Drag.Move ईवेंट विभिन्न कार्य प्रदान करते हैं जिनका उपयोग कार्रवाई के विभिन्न स्तरों में किया जा सकता है। उदाहरण के लिए, जब आप किसी ऑब्जेक्ट को खींचना या छोड़ना शुरू करते हैं, तो प्रत्येक Drag.Move ईवेंट ड्रैग किए गए तत्व या गिराए गए तत्व को पैरामीटर के रूप में पास करेगा।

निम्नलिखित समर्थित घटनाएँ हैं -

onStart ()

यह ड्रैग की शुरुआत में एक घटना को बढ़ाता है। यदि आप एक लंबा स्नैप सेट करते हैं, तो यह घटना तब तक नहीं बढ़ेगी जब तक कि माउस कुछ दूरी पर न हो। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // Drag options will pass the dragged element as a parameter
   onStart: function(el) {
      // put whatever you want to happen on start in here
   }
});

onDrag ()

जब आप किसी तत्व को खींच रहे हैं, तो यह एक घटना को लगातार बढ़ाता है। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // Drag options will pass the dragged element as a parameter
   onDrag: function(el) {
      // put whatever you want to happen on drag in here
   }
});

onDrop ()

यह एक घटना को बढ़ाता है जब आप ड्रैग करने योग्य तत्व को ड्रापेबल तत्व में छोड़ते हैं। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // It will pass the draggable element ('el' in this case)
   // and the droppable element the draggable is interacting with ('dr' here)
   onDrop: function(el, dr) {
      // put whatever you want to happen on drop in here
   }
});

छुट्टी पर()

यह एक घटना को बढ़ाता है जब एक ड्रैग करने योग्य तत्व एक ड्रापेबल तत्व की सीमा को छोड़ देता है। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // It will pass the draggable element ('el' in this case)
   // and the droppable element the draggable is interacting with ('dr' here)
   onLeave: function(el, dr) {
      // put whatever you want to happen on Leave from droppable area in here
   }
});

onEnter ()

यह तब होता है जब एक ड्रैग करने योग्य तत्व एक ड्रापेबल तत्व क्षेत्र में प्रवेश करता है। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // It will pass the draggable element ('el' in this case)
   // and the droppable element the draggable is interacting with ('dr' here)
   onEnter: function(el, dr) {
      // this will fire when a draggable enters a droppable element
   }
});

onComplete ()

इससे एक घटना सामने आती है। onComplete का तात्पर्य है जब आप एक बूंद को गिराते हैं, और यह बढ़ाएगा कि क्या आप एक बूंद में उतरते हैं या नहीं। निम्नलिखित सिंटैक्स पर एक नज़र डालें।

Syntax

var myDrag = new Drag.Move(dragElement , {
   // Drag Options
   // Drag options will pass the dragged element as a parameter
   onComplete: function(el) {
      // put whatever you want to happen on complete
   }
});

आइए एक उदाहरण लेते हैं जो इस अध्याय में बताई गई सभी विशेषताओं का पता लगाएगा। विशेषताएं हैं - ड्रैग, ड्रैग.मूव, ऑनएंटर, ऑनलेव, ऑनड्रॉप, ऑनस्टार्ट, ऑनड्रैग, और ऑनकंप्लीट। इस उदाहरण में, हम एक हैण्डल प्रदान कर रहे हैं, जिसके प्रयोग से आप ड्रैग करने योग्य वस्तु को कंटेनर में कहीं भी खींच सकते हैं। प्रत्येक क्रिया के लिए, बाईं ओर एक अधिसूचना है (नीले रंग में इंगित)। कंटेनर में एक ड्रोपेबल क्षेत्र है। यदि ड्रैगजेबल ऑब्जेक्ट ड्रोपेबल क्षेत्र में प्रवेश करता है, तो अंतिम तीन संकेतक सक्रिय होते हैं। निम्नलिखित कोड पर एक नज़र डालें।

Example

<!DOCTYPE html>
<html>

   <head>
      <style>
         /* this is generally a good idea */
         body {
            margin: 0;
            padding: 0;
         }
         
         /* make sure the draggable element has "position: absolute"
         and then top and left are set for the start position */
         #drag_me {
            width: 100px;
            height: 100px;
            background-color: #333;
            position: absolute;
            top: 0;
            left: 0;
         }
         #drop_here {
            width: 80%;
            height: 200px;
            background-color: #eee;
            margin-left: 100px;
            margin-top: -200px !important;
         }
         /* make sure the drag container is set with position relative */
         #drag_cont {
            background-color: #ccc;
            height: auto;
            width: 500px;
            position:relative;
            margin-top: 20px;
            margin-left: 20px;
            margin-bottom: auto;
         }
         #drag_me_handle {
            width: 100%;
            height: auto;
            background-color: #F5B041;
         }
         #drag_me_handle span {
            display: block;
            padding: 20px;
         }
         .indicator {
            width: 100px;
            height: auto;
            background-color: #0066FF;
            border-bottom: 1px solid #eee;
         }
         .indicator span {
            padding: 10px;
            display: block;
         }
         .draggable {
            width: 200px;
            height: 200px;
            background-color: blue;
         }
      </style>
      
      <script type = "text/javascript" src = "MooTools-Core-1.6.0.js"></script>
      <script type = "text/javascript" src = "MooTools-More-1.6.0.js"></script>
      
      <script type = "text/javascript">
         window.addEvent('domready', function() {
            var dragElement = $('drag_me');
            var dragContainer = $('drag_cont');
            var dragHandle = $('drag_me_handle');
            var dropElement = $$('.draggable');
            var startEl = $('start');
            var completeEl = $('complete');
            var dragIndicatorEl = $('drag_ind');
            var enterDrop = $('enter');
            var leaveDrop = $('leave');
            var dropDrop = $('drop_in_droppable');
            
            var myDrag = new Drag.Move(dragElement, {
               // Drag.Move options
               droppables: dropElement,
               container: dragContainer,
               
               // Drag options
               handle: dragHandle,
               
               // Drag.Move Events
               onDrop: function(el, dr) {
                  if (!dr) { }else {
                     dropDrop.highlight('#FB911C'); //flashes orange
                     el.highlight('#fff'); //flashes white
                     dr.highlight('#667C4A'); //flashes green
                  };
               },
               onLeave: function(el, dr) {
                  leaveDrop.highlight('#FB911C'); //flashes orange
               },
               onEnter: function(el, dr) {
                  enterDrop.highlight('#FB911C'); //flashes orange
               },
               
               // Drag Events
               onStart: function(el) {
                  startEl.highlight('#FB911C'); //flashes orange
               },
               onDrag: function(el) {
                  dragIndicatorEl.highlight('#FB911C'); //flashes orange
               },
               onComplete: function(el) {
                  completeEl.highlight('#FB911C'); //flashes orange
               }
            });
         });
      </script>
   </head>
   
   <body>
   
      <p align = "center">Drag and Drop Application</p>
      <div id = "drag_cont">
         <div id = "start" class = "indicator"><span>Start</span></div>
         <div id = "drag_ind" class = "indicator"><span>Drag</span></div>
         <div id = "complete" class = "indicator"><span>Complete</span></div>
         <div id = "enter" class = "indicator"><span>Enter Droppable Element</span></div>
         <div id = "leave" class = "indicator"><span>Leave Droppable Element</span></div>
         
         <div id = "drop_in_droppable" class = "indicator">
            <span>Dropped in Droppable Element</span>
         </div>
         
         <div id = "drag_me">
            <div id = "drag_me_handle"><span>HANDLE</span></div>
         </div>
         
         <div id = "drop_here" class = "draggable">
            <p align = "center">Droppable Area</p>
         </div>
         
      </div>
   </body>
   
</html>

आपको निम्न आउटपुट प्राप्त होंगे, जिसमें आपको हैंडल पर क्लिक करना होगा और उसे ड्रैग करना होगा। अब आप बाईं ओर अधिसूचना संकेत पा सकते हैं।

Output