आयनिक - जावास्क्रिप्ट साइड मेनू

साइड मेनू सबसे अधिक उपयोग किए जाने वाले आयनिक घटकों में से एक है। साइड मेनू को बाईं या दाईं ओर स्वाइप करके या उस उद्देश्य के लिए बनाए गए बटन को ट्रिगर करके खोला जा सकता है।

साइड मेनू का उपयोग करना

पहला तत्व जो हमें चाहिए ion-side-menus। इस तत्व का उपयोग साइड मेनू को उन सभी स्क्रीन के साथ जोड़ने के लिए किया जाता है जो इसका उपयोग करेंगे। ion-side-menu-content तत्व वह है जहाँ सामग्री रखी जाएगी और ion-side-menu तत्व वह जगह है जहां हम एक डाल सकते हैं sideनिर्देश। हम साइड मेनू को इसमें जोड़ देंगेindex.html और जगह है ion-nav-viewसाइड मेनू सामग्री के अंदर। इस तरह से साइड मेनू का उपयोग पूरे ऐप में किया जा सकता है।

index.html

<ion-side-menus>

   <ion-side-menu>side = "left">
      <h1>SIde Menu</h1>
   </ion-side-menu>

   <ion-side-menu-content>
      <ion-nav-view>
      </ion-nav-view>
   </ion-side-menu-content>

</ion-side-menus>

अब, हम बटन बनाएंगे with menu-toggle = "left"निर्देश। यह बटन आमतौर पर ऐप्स हेडर बार में रखा जाएगा, लेकिन हम इसे बेहतर समझ के लिए अपनी टेम्पलेट फ़ाइल में जोड़ देंगे।

जब बटन टैप किया जाता है या जब हम दाईं ओर स्वाइप करते हैं, तो साइड मेनू खुल जाएगा। आप भी सेट कर सकते हैंmenu-close निर्देश, यदि आप साइड मेनू बंद करने के लिए केवल एक बटन रखना चाहते हैं, लेकिन हम इसके लिए टॉगल बटन का उपयोग करेंगे।

HTML टेम्पलेट

<button menu-toggle = "left" class = "button button-icon icon ion-navicon"></button>

उपरोक्त कोड निम्नलिखित स्क्रीन का उत्पादन करेगा -

आप कुछ अतिरिक्त विशेषताओं को जोड़ सकते हैं ion-side-menusतत्व। enable-menu-with-back-viewsसाइड बटन को अक्षम करने के लिए गलत पर सेट किया जा सकता है, जब बैक बटन दिखाया जाता है। यह भी छुप जाएगाmenu-toggleहेडर से बटन। दूसरी विशेषता हैdelegate-handle, जिसका उपयोग कनेक्शन के लिए किया जाएगा $ionicSideMenuDelegate

ion-side-menu-contentतत्व अपनी विशेषता का उपयोग कर सकता है। जबdrag-contentविशेषता झूठी पर सेट है, यह सामग्री स्क्रीन को स्वाइप करके साइड मेनू को खोलने की क्षमता को अक्षम कर देगा। edge-drag-thresholdविशेषता का डिफ़ॉल्ट मान 25 है। इसका मतलब है कि स्क्रीन के बाएं और दाएं किनारे से केवल 25 पिक्सेल स्वाइप करने की अनुमति है। हम इस संख्या मान को बदल सकते हैं या हम इसे सेट कर सकते हैंfalse संपूर्ण स्क्रीन पर स्वाइप करना या सक्षम करना true इसे निष्क्रिय करने के लिए।

ion-side-menu का उपयोग कर सकते हैं sideविशेषता जो हमने ऊपर के उदाहरण में दिखाई। यह निर्धारित करेगा कि मेनू बाईं या दाईं ओर से प्रकट होना चाहिए या नहीं। ‘is-enabled’ झूठे मूल्य के साथ विशेषता पक्ष मेनू को अक्षम कर देगी, और widthविशेषता मान एक संख्या है जो यह दर्शाता है कि साइड मेनू कितना चौड़ा होना चाहिए। डिफ़ॉल्ट मान 275 है।

साइड मेनू प्रतिनिधि

$ionicSideMenuDelegateऐप में सभी साइड मेनू को नियंत्रित करने के लिए उपयोग की जाने वाली सेवा है। हम आपको बताएंगे कि इसका उपयोग कैसे करना है, और फिर हम उपलब्ध सभी विकल्पों के माध्यम से जाएंगे। सभी आयोनिक सेवाओं की तरह, हमें इसे अपने नियंत्रक पर निर्भरता के रूप में जोड़ना होगा और फिर इसे नियंत्रक के दायरे के अंदर उपयोग करना होगा। अब जब हम बटन पर क्लिक करते हैं, तो सभी साइड मेनू खुल जाएंगे।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicSideMenuDelegate) {
   $scope.toggleLeftSideMenu = function() {
      $ionicSideMenuDelegate.toggleLeft();
   };
})

HTML कोड

<button class = "button button-icon icon ion-navicon" ng-click = "toggleLeft()"></button>

निम्न तालिका से पता चलता है $ionicScrollDelegate तरीकों।

डेलिगेट तरीके

तरीका मापदंडों प्रकार विवरण
toggleLeft (पैरामीटर) खुला हैं बूलियन साइड मेनू खोलने या बंद करने के लिए उपयोग किया जाता है।
toggleRight (पैरामीटर) खुला हैं बूलियन साइड मेनू खोलने या बंद करने के लिए उपयोग किया जाता है।
getOpenRatio () / / मेनू चौड़ाई पर खुले भाग का रिटर्न अनुपात। यदि मेनू का आधा भाग बाईं ओर से खुला है, तो राशन 0.5 होगा। यदि साइड मेनू बंद है, तो यह 0. वापस आ जाएगा। यदि मेनू का आधा भाग दाईं ओर से खुला है, तो यह -0.5 पर वापस आ जाएगा।
खुला हैं() / बूलियन सही है अगर साइड मेनू खुला है, तो गलत है अगर यह बंद है।
isOpenLeft () / बूलियन यदि बाईं ओर का मेनू खुला है, तो गलत है, यदि वह बंद है तो सही है।
isOpenRight () / बूलियन यदि सही साइड मेनू खुला है, तो गलत है अगर यह बंद हो जाता है।
getScrollPosition () / / गुण के रूप में दो नंबर के साथ वस्तु लौटाता है: left तथा right। ये संख्या उपयोगकर्ता द्वारा बाईं ओर और ऊपर से क्रमशः स्क्रॉल की गई दूरी का प्रतिनिधित्व करती है।
canDragContent (parameter1) canDrag बूलियन क्या सामग्री को साइड मेनू खोलने के लिए खींचा जा सकता है।
edgeDragThreshold (parameter1) मूल्य बूलियन | संख्या मान है तो true, साइड मेनू स्क्रीन के किनारों से 25px खींचकर खोला जा सकता है। यदि यह गलत है, तो ड्रैग करना अक्षम है। हम किसी भी संख्या को सेट कर सकते हैं जो स्क्रीन के बाएँ और दाएँ किनारे से पिक्सेल मान का प्रतिनिधित्व करेगा।
$ GetByHandle (parameter1) हैंडल तार एक ही हैंडल से विशेष साइड मेनू दृश्य में तरीकों को जोड़ने के लिए उपयोग किया जाता है। $ionicSideMenuDelegate. $getByHandle('my-handle').toggleLeft();