आयनिक - जावास्क्रिप्ट स्क्रॉल

आयनिक ऐप्स में हेरफेर स्क्रॉल करने के लिए उपयोग किए जाने वाले तत्व को कहा जाता है ion-scroll

स्क्रॉल का उपयोग करना

निम्नलिखित कोड स्निपेट स्क्रॉल करने योग्य कंटेनर बनाएंगे और स्क्रॉलिंग पैटर्न समायोजित करेंगे। सबसे पहले, हम अपना HTML एलिमेंट बनाएंगे और उसमें गुण जोड़ेंगे। हम जोड़ देंगे →direction = "xy"हर तरफ स्क्रॉल करने की अनुमति देना। हम स्क्रॉल तत्व के लिए चौड़ाई और ऊंचाई भी निर्धारित करेंगे।

HTML कोड

<ion-scroll zooming = "true" direction = "xy" style = "width: 320px; height: 500px">
   <div class = "scroll-container"></div>
</ion-scroll>

इसके बाद, हम अपने विश्व मानचित्र की छवि को इसमें जोड़ देंगे div तत्व, जिसे हमने अंदर बनाया है ion-scroll और इसकी चौड़ाई और ऊंचाई निर्धारित करें।

सीएसएस कोड

.scroll-container {
   width: 2600px;
   height: 1000px;
   background: url('../img/world-map.png') no-repeat
}

जब हम अपना ऐप चलाते हैं, तो हम हर दिशा में नक्शे को स्क्रॉल कर सकते हैं। निम्न उदाहरण मानचित्र के उत्तरी अमेरिका भाग को दर्शाता है।

हम इस नक्शे को किसी भी हिस्से तक स्क्रॉल कर सकते हैं जो हम चाहते हैं। आइए हम इसे एशिया दिखाने के लिए स्क्रॉल करें।

अन्य विशेषताएँ हैं, जिन्हें लागू किया जा सकता है ion-scroll। आप उन्हें निम्न तालिका में देख सकते हैं।

स्क्रॉल विशेषताएँ

गुण प्रकार विवरण
दिशा तार स्क्रॉल की संभावित दिशाएँ। डिफ़ॉल्ट मान हैy
प्रतिनिधि-संभाल तार के साथ स्क्रॉल पहचान के लिए उपयोग किया जाता है $ionicScrollDelegate
ताला बूलियन एक समय में एक दिशा में स्क्रॉल लॉक करने के लिए उपयोग किया जाता है। डिफ़ॉल्ट मान सत्य है।
पेजिंग बूलियन यह निर्धारित करने के लिए उपयोग किया जाता है कि पेजिंग का उपयोग स्क्रॉल के साथ किया जाएगा या नहीं।
ऑन-ताज़ा अभिव्यक्ति पुल-टू-रिफ्रेश पर कॉल किया गया।
ऑन-पुस्तक अभिव्यक्ति स्क्रॉल करने पर कॉल किया गया।
स्क्रॉलबार-x बूलियन क्षैतिज स्क्रॉल बार दिखाया जाना चाहिए। डिफ़ॉल्ट मान सत्य है।
स्क्रॉलबार-y तार वर्टिकल स्क्रॉल बार दिखाना चाहिए। डिफ़ॉल्ट मान सत्य है।
ज़ूमिंग बूलियन चुटकी-दर-जूम लगाने के लिए उपयोग किया जाता है।
मिनट-जूम पूर्णांक न्यूनतम ज़ूम मान।
अधिकतम ज़ूम पूर्णांक अधिकतम ज़ूम मान।
स्क्रॉलबार-x बूलियन बाउंसिंग को सक्षम करने के लिए उपयोग किया जाता है। Android झूठी पर IOS पर डिफ़ॉल्ट मान सही है।

अनंत सूची

जब पृष्ठ के निचले भाग में स्क्रॉल किया जाता है, तो कुछ व्यवहार को ट्रिगर करने के लिए एक अनंत स्क्रॉल का उपयोग किया जाता है। निम्न उदाहरण दिखाता है कि यह कैसे काम करता है। हमारे नियंत्रक में, हमने सूची में आइटम जोड़ने के लिए एक फ़ंक्शन बनाया। जब स्क्रॉल अंतिम लोड किए गए तत्व का 10% गुजरता है तो ये आइटम जोड़े जाएंगे। यह तब तक जारी रहेगा जब तक हम 30 लोडेड तत्वों को नहीं मारते। हर बार लोडिंग समाप्त हो जाती है,on-infinite प्रसारित होगा scroll.infiniteScrollComplete प्रतिस्पर्धा।

HTML कोड

<ion-list>
   <ion-item ng-repeat = "item in items" item = "item">Item {{ item.id }}</ion-item>
</ion-list>

<ion-infinite-scroll ng-if = "!noMoreItemsAvailable" on-infinite = "loadMore()" 
   distance = "10%"></ion-infinite-scroll>

नियंत्रक कोड

.controller('MyCtrl', function($scope) {
   $scope.items = [];
   $scope.noMoreItemsAvailable = false;
   
   $scope.loadMore = function() {
      $scope.items.push({ id: $scope.items.length}); 

      if ($scope.items.length == 30) {
         $scope.noMoreItemsAvailable = true;
      }
   
      $scope.$broadcast('scroll.infiniteScrollComplete');
   };
})

अन्य विशेषताओं का भी उपयोग किया जा सकता है ion-infinite-scroll। उनमें से कुछ नीचे दी गई तालिका में सूचीबद्ध हैं।

स्क्रॉल विशेषताएँ

गुण प्रकार विवरण
ऑन-अनंत अभिव्यक्ति नीचे स्क्रॉल करने पर क्या कहा जाना चाहिए।
दूरी तार अनंत अभिव्यक्ति को ट्रिगर करने के लिए नीचे से दूरी की आवश्यकता होती है।
स्पिनर तार लोड करते समय क्या स्पिनर दिखाया जाना चाहिए
तत्काल की जांच बूलियन स्क्रीन लोड होने पर 'ऑन-इनफिनिट' कहा जाना चाहिए

स्क्रॉल प्रतिनिधि

आयोनिक स्क्रॉल तत्वों के पूर्ण नियंत्रण के लिए प्रतिनिधि प्रदान करता है। यह एक इंजेक्शन लगाने के द्वारा इस्तेमाल किया जा सकता है$ionicScrollDelegate नियंत्रक के लिए सेवा, और फिर यह प्रदान करता है तरीकों का उपयोग करें।

निम्नलिखित उदाहरण 20 वस्तुओं की एक स्क्रॉल करने योग्य सूची दिखाता है।

HTML कोड

<div class = "list">
   <div class = "item">Item 1</div>
   <div class = "item">Item 2</div>
   <div class = "item">Item 3</div>
   <div class = "item">Item 4</div>
   <div class = "item">Item 5</div>
   <div class = "item">Item 6</div>
   <div class = "item">Item 7</div>
   <div class = "item">Item 8</div>
   <div class = "item">Item 9</div>
   <div class = "item">Item 10</div>
   <div class = "item">Item 11</div>
   <div class = "item">Item 12</div>
   <div class = "item">Item 13</div>
   <div class = "item">Item 14</div>
   <div class = "item">Item 15</div>
   <div class = "item">Item 16</div>
   <div class = "item">Item 17</div>
   <div class = "item">Item 18</div>
   <div class = "item">Item 19</div>
   <div class = "item">Item 20</div>
</div>

<button class = "button" ng-click = "scrollTop()">Scroll to Top!</button>

नियंत्रक कोड

.controller('DashCtrl', function($scope, $ionicScrollDelegate) {

   $scope.scrollTop = function() {
      $ionicScrollDelegate.scrollTop();
   };
})

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

जब हम बटन पर टैप करते हैं, तो स्क्रॉल को शीर्ष पर ले जाया जाएगा।

अब, हम सभी के माध्यम से जाना जाएगा $ionicScrollDelegate तरीकों।

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

तरीका मापदंडों प्रकार विवरण
scrollTop (पैरामीटर) shouldAnimate बूलियन स्क्रॉल एनिमेटेड होना चाहिए।
scrollBottom (पैरामीटर) shouldAnimate बूलियन स्क्रॉल एनिमेटेड होना चाहिए।
स्क्रोल्टो (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) बाएं, ऊपर, कंधे संख्या, संख्या, पूर्णांक पहले दो पैरामीटर x का मान निर्धारित करते हैं, और y- अक्ष ऑफ़सेट।
स्क्रॉलबी (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) बाएं, ऊपर, कंधे संख्या, संख्या, पूर्णांक पहले दो पैरामीटर x का मान निर्धारित करते हैं, और y- अक्ष ऑफ़सेट।
ZoomTo (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3, पैरामीटर 4) स्तर, चेतन, उत्पत्ति, मूल संख्या, बूलियन, संख्या, संख्या level को ज़ूम करने के लिए स्तर निर्धारित करने के लिए उपयोग किया जाता है। originLeft तथा originRight निर्देशांक जहां ज़ूमिंग होनी चाहिए।
zoomBy (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3, पैरामीटर 4) कारक, चेतन, ओरिफ्लेफ्ट, ओरिजनल टॉप संख्या, बूलियन, संख्या, संख्या factor द्वारा ज़ूम करने के लिए कारक निर्धारित करने के लिए उपयोग किया जाता है। originLeft तथा originRight निर्देशांक जहां ज़ूमिंग होनी चाहिए।
getScrollPosition () / / गुण के रूप में दो नंबर के साथ वस्तु लौटाता है: left तथा right। ये संख्या उपयोगकर्ता द्वारा बाईं ओर और ऊपर से क्रमशः स्क्रॉल की गई दूरी का प्रतिनिधित्व करती है।
anchorScroll (parameter1) shouldAnimate बूलियन यह तत्व को उसी आईडी के साथ स्क्रॉल करेगा, जिसमें window.loaction.hash। यदि यह तत्व मौजूद नहीं है, तो यह शीर्ष पर स्क्रॉल जाएगा।
freezeScroll (parameter1) shouldFreeze बूलियन विशेष स्क्रॉल के लिए स्क्रॉलिंग को अक्षम करने के लिए उपयोग किया जाता है।
freezeAllScrolls (parameter1) shouldFreeze बूलियन एप्लिकेशन में सभी स्क्रॉल के लिए स्क्रॉलिंग को अक्षम करने के लिए उपयोग किया जाता है।
getScrollViews () / वस्तु स्क्रॉलव्यू ऑब्जेक्ट लौटाता है।
$ GetByHandle (parameter1) हैंडल तार एक ही हैंडल के साथ विशेष स्क्रॉल दृश्य में विधियों को जोड़ने के लिए उपयोग किया जाता है। $ionicScrollDelegate. $getByHandle('my-handle').scrollTop();