MooTools - Fx.Slide

Fx.Slides एक विकल्प है जो आपको सामग्री को दृश्य में स्लाइड करके प्रदर्शित करता है। यह बहुत ही सरल है लेकिन आपके UI के लुक को बढ़ाता है।

आइए Fx.Slide, इसके विकल्प और तरीकों को बनाने और शुरू करने के बारे में चर्चा करें।

सबसे पहले, हम उपयोगकर्ता द्वारा परिभाषित उदाहरण के साथ Fx.Slide वर्ग को इनिशियलाइज़ करेंगे। उसके लिए, हमें एक HTML एलिमेंट बनाना और चुनना होगा। उसके बाद, हम इन तत्वों के लिए सीएसएस लागू करेंगे। अंत में, हम अपने तत्व चर के साथ Fx.Slide का एक नया उदाहरण आरंभ करेंगे।

Fx.Slide विकल्प

केवल दो Fx.Slide विकल्प हैं - मोड और आवरण।

मोड

मोड आपको दो विकल्प देता है, 'ऊर्ध्वाधर' या 'क्षैतिज'। ऊर्ध्वाधर ऊपर से नीचे और क्षैतिज से पता चलता है बाएँ से दाएँ। नीचे से ऊपर या दाएं से बाएं जाने का कोई विकल्प नहीं है, मैं समझता हूं कि इसे पूरा करने के लिए कक्षा को हैक करना अपेक्षाकृत सरल है। मेरी राय में, यह एक ऐसा विकल्प है जिसे मैं मानक देखना चाहता हूं, और अगर किसी ने इस विकल्प की अनुमति देने के लिए कक्षा को हैक किया है, तो कृपया हमें एक नोट छोड़ दें।

आवरण

डिफ़ॉल्ट रूप से, Fx.Slide आपके स्लाइड तत्व के चारों ओर एक रैपर फेंकता है, जो इसे 'अतिप्रवाह': 'छिपा हुआ' देता है। रैपर आपको रैपर के रूप में एक और तत्व सेट करने की अनुमति देता है। जैसा कि मैंने ऊपर कहा, मैं स्पष्ट नहीं हूं कि यह कहां काम आएगा और किसी भी विचार को सुनने के लिए दिलचस्पी होगी (मुझे यह स्पष्ट करने में मदद करने के लिए mooforum.net पर हॉर्सवेपॉन के लिए धन्यवाद)।

Fx.Slide तरीके

Fx.Slide अपने तत्व को दिखाने और छिपाने के लिए कई तरीके भी पेश करता है।

अंदर फिसलना()

जैसा कि नाम से ही स्पष्ट है, यह विधि स्टार्ट ईवेंट को आग लगा देगी और आपके तत्व को प्रकट कर देगी।

फिसल जाना()

आपके तत्व को छिपी हुई स्थिति में वापस ले जाता है।

टॉगल ()

यह या तो तत्व को अंदर या बाहर स्लाइड करेगा, जो इसकी वर्तमान स्थिति पर निर्भर करता है। घटनाओं को क्लिक करने के लिए जोड़ने के लिए बहुत उपयोगी विधि।

छिपाना()

यह स्लाइड प्रभाव के बिना तत्व को छिपाएगा।

प्रदर्शन()

यह स्लाइड प्रभाव के बिना तत्व दिखाएगा।

Fx.Slide शॉर्टकट

Fx.Slide वर्ग एक तत्व में प्रभाव जोड़ने के लिए कुछ आसान शॉर्टकट भी प्रदान करता है।

सेट ( 'स्लाइड')

एक नई कक्षा शुरू करने के बजाय, आप एक तत्व पर 'सेट' स्लाइड करने पर एक नया उदाहरण बना सकते हैं।

Syntax

slideElement.set('slide');

विकल्प सेट करना

आप शॉर्टकट के साथ विकल्प भी सेट कर सकते हैं -

Syntax

slideElement.set('slide', {duration: 1250});

फिसल पट्टी()

एक बार स्लाइड .set () होने के बाद, आप इसे .slide () विधि से आरंभ कर सकते हैं।

Syntax

slideElement.slide('in');

.slide स्वीकार करेंगे -

  • ‘in’
  • ‘out’
  • ‘toggle’
  • ’show’
  • ‘hide’

... ऊपर दिए गए तरीकों से संबंधित प्रत्येक।

Example

आइए एक उदाहरण लेते हैं जो Fx.Slide के बारे में बताते हैं। निम्नलिखित कोड पर एक नज़र डालें।

<!DOCTYPE html>
<html>
   
   <head>
      <style>
         .ind {
            width: 200px;
            padding: 10px;
            background-color: #87AEE1;
            font-weight: bold;
            border-bottom: 1px solid white;
         }
         .slide {
            margin: 20px 0; 
            padding: 10px;
            width: 200px;
            background-color: #F9E79F;
         }
         #slide_wrap {
            padding: 30px;
            background-color: #D47000;
         }
      </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 slideElement = $('slideA');
            
            var slideVar = new Fx.Slide(slideElement, {
               //Fx.Slide Options
               mode: 'horizontal', //default is 'vertical'
               
               //wrapper: this.element, //default is this.element
               //Fx Options
               link: 'cancel',
               transition: 'elastic:out',
               duration: 'long', 
               
               //Fx Events
               onStart: function(){
                  $('start').highlight("#EBCC22");
               },
               
               onCancel: function(){
                  $('cancel').highlight("#EBCC22");
               },
               
               onComplete: function(){
                  $('complete').highlight("#EBCC22");
               }
            }).hide().show().hide(); //note, .hide and .show do not fire events 

            $('openA').addEvent('click', function(){
               slideVar.slideIn();
            });

            $('closeA').addEvent('click', function(){
               slideVar.slideOut();
            });

            //EXAMPLE B
            var slideElementB = $('slideB');
            var slideVarB = new Fx.Slide(slideElementB, {
            
               //Fx.Slide Options
               mode: 'vertical', //default is 'vertical'
               link: 'chain', 
               
               //Fx Events
               onStart: function(){
                  $('start').highlight("#EBCC22");
               },
               
               onCancel: function(){
                  $('cancel').highlight("#EBCC22");
               },
               
               onComplete: function(){
                  $('complete').highlight("#EBCC22");
               }
            });

            $('openB').addEvent('click', function(){
               slideVarB.slideIn();
            });

            $('closeB').addEvent('click', function(){
               slideVarB.slideOut();
            });
         });
      </script>
   </head>

   <body>
      <div id = "start" class = "ind">Start</div>
      <div id = "cancel" class = "ind">Cancel</div>
      <div id = "complete" class = "ind">Complete</div>
 
      <button id = "openA">open A</button>
      <button id = "closeA">close A</button>

      <div id = "slideA" class = "slide">Here is some content - A. Notice the delay 
         before onComplete fires.  This is due to the transition effect, the onComplete 
         will not fire until the slide element stops "elasticing." Also, notice that 
         if you click back and forth, it will "cancel" the previous call and give the 
         new one priority.</div>
 
      <button id = "openB">open B</button>
      <button id = "closeB">close B</button>

      <div id = "slideB" class = "slide">Here is some content - B. Notice how 
         if you click me multiple times quickly I "chain" the events.  This slide is 
         set up with the option "link: 'chain'"</div>
         
   </body>
</html>

Output

बटन पर क्लिक करें - ओपनए, क्लोजा, ओपनबी और क्लोजबी। संकेतकों पर परिवर्तन, प्रभाव और घटना की अधिसूचना देखें।