आयनिक - जावास्क्रिप्ट नेविगेशन

नेविगेशन हर ऐप के मुख्य घटकों में से एक है। आयनिक का उपयोग कर रहा हैAngularJS UI Router नेविगेशन को संभालने के लिए।

नेविगेशन का उपयोग करना

नेविगेशन में कॉन्फ़िगर किया जा सकता है app.jsफ़ाइल। यदि आप एक आयोनिक टेम्प्लेट का उपयोग कर रहे हैं, तो आप नोटिस करेंगे$stateProvider एप्लिकेशन में इंजेक्शन इंजेक्शन config। एप्लिकेशन के लिए राज्य बनाने का सबसे सरल तरीका निम्नलिखित उदाहरण में दिखाया गया है।

$stateProvider सेवा URL को स्कैन करेगी, संबंधित स्थिति ढूंढेगी और फ़ाइल लोड करेगी, जिसे हमने परिभाषित किया था app.config

app.js कोड

.config(function($stateProvider) {
   $stateProvider
   .state('index', { url: '/', templateUrl: 'templates/home.html'})
   .state('state1', {url: '/state1', templateUrl: 'templates/state1.html'})
   .state('state2', {url: '/state2', templateUrl: 'templates/state2.html',});
});

राज्य में लोड किया जाएगा ion-nav-view तत्व, जिसे में रखा जा सकता है index.html तन।

index.html कोड

<ion-nav-view></ion-nav-view>

जब हमने उपर्युक्त उदाहरण में राज्यों का निर्माण किया, तो हम इसका उपयोग कर रहे थे templateUrl, इसलिए जब स्थिति लोड हो जाती है, तो यह टेम्पलेट फ़ाइल के मिलान के लिए खोज करेगा। अब, हम खुलेंगेtemplates फ़ोल्डर और एक नई फ़ाइल बनाएँ state1.html, जिसे ऐप URL में बदलने पर लोड किया जाएगा /state1

state1.html Code

<ion-view>
   <ion-content>
      This is State 1 !!!
   </ion-content>
</ion-view>

नेविगेशन मेनू बनाना

आप अपने ऐप में एक नेविगेशन बार जोड़ सकते हैं index.html जोड़कर शरीर “ion-nav-bar”तत्व। नेविगेशन बार के अंदर, हम जोड़ देंगेion-nav-back-buttonएक आइकन के साथ। इसका उपयोग पिछली स्थिति में लौटने के लिए किया जाएगा। राज्य बदलने पर बटन अपने आप दिखाई देगा। हम असाइन करेंगेgoBack() फ़ंक्शन, जो उपयोग करेगा $ionicHistoryइस कार्यक्षमता को संभालने के लिए सेवा। इसलिए, जब उपयोगकर्ता होम स्टेट को छोड़ता है और जाता हैstate1बैक बटन दिखाई देगा जिसे टैप किया जा सकता है, अगर उपयोगकर्ता होम स्टेट पर लौटना चाहता है।

index.html कोड

<ion-nav-bar class = "bar-positive">
   <ion-nav-back-button class = "button-clear" ng-click = "goBack()">
      <i class = "icon ion-arrow-left-c"></i> Back
   </ion-nav-back-button>
</ion-nav-bar>

नियंत्रक कोड

.MyCtrl($scope, $ionicHistory) {
   $scope.goBack = function() {
      $ionicHistory.goBack();
   };
}

नेविगेशन तत्व जोड़ना

बटन का उपयोग करके नेविगेशन बार में जोड़ा जा सकता है ion-nav-buttons। इस तत्व को अंदर रखा जाना चाहिएion-nav-bar या ion-view। हम असाइन कर सकते हैंsideचार विकल्प मूल्यों के साथ विशेषता। primary तथा secondaryमान का उपयोग किए गए प्लेटफ़ॉर्म के अनुसार बटन लगाएंगे। कभी-कभी आप एक तरफ बटन चाहते हैं, चाहे वह आईओएस या एंड्रॉइड हो। अगर ऐसा है, तो आप इसका उपयोग कर सकते हैंleft या right इसके बजाय विशेषताएँ।

हम भी जोड़ सकते हैं ion-nav-titleनेविगेशन बार के लिए। सभी कोड में रखा जाएगाindex.html शरीर, इसलिए यह हर जगह इस्तेमाल किया जा सकता है।

<ion-nav-bar class = "bar-positive">
   <ion-nav-title>
      Title
   </ion-nav-title>
	
   <ion-nav-buttons side = "primary">
      <button class = "button">
         Button 1
      </button>
   </ion-nav-buttons>
</ion-nav-bar>

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

अन्य नेविगेशन विशेषताएँ

निम्न तालिका कुछ अन्य कार्यशीलता को दर्शाती है, जिसका उपयोग आयोनिक नेविगेशन के साथ किया जा सकता है।

नेविगेशन विशेषताएँ

गुण विकल्प विस्तार
नव-संक्रमण कोई नहीं, iOS, Android एनीमेशन सेट करने के लिए उपयोग किया जाता है जिसे संक्रमण होने पर लागू किया जाना चाहिए।
नव-दिशा आगे, पीछे, दर्ज करें, बाहर निकलें, स्वैप करें जब संक्रमण होता है तो एनीमेशन की दिशा निर्धारित करने के लिए उपयोग किया जाता है।
hardwareBackButtonClose बूलियन हार्डवेयर बैक बटन पर क्लिक करने पर यह मोडल को बंद करने में सक्षम होगा। डिफ़ॉल्ट मान सत्य है।

कैशिंग

Ionic के पास प्रदर्शन को बेहतर बनाने के लिए दस विचारों तक कैशिंग करने की क्षमता है। यह मैन्युअल रूप से कैशिंग को संभालने का एक तरीका भी प्रदान करता है। चूँकि केवल पिछड़े विचारों को कैश किया जाता है और आगे वाले प्रत्येक बार उपयोगकर्ताओं द्वारा जाने पर लोड कर रहे हैं, हम आसानी से कोड का उपयोग करके आगे के विचारों को कैश करने के लिए सेट कर सकते हैं।

$ionicCinfigProvider.views.forwardCache(true);

हम यह भी निर्धारित कर सकते हैं कि कितने राज्यों में कैश होना चाहिए। यदि हम चाहते हैं कि तीन दृश्य कैश्ड हों, तो हम निम्नलिखित कोड का उपयोग कर सकते हैं।

$ionicConfigProvider.views.maxCache(3);

कैशिंग को अंदर अक्षम किया जा सकता है $stateProvider या करने के लिए विशेषता सेट करके ion-view। दोनों उदाहरण नीचे हैं।

$stateProvider.state('state1', {
   cache: false,
   url : '/state1',
   templateUrl: 'templates/state1.html'
})

<ion-view cache-view = "false"></ion-view>

नेविगेशन बार को नियंत्रित करना

हम नेविगेशन बार के उपयोग को नियंत्रित कर सकते हैं $ionicNavBarDelegateसर्विस। इस सेवा को हमारे नियंत्रक को इंजेक्ट करने की आवश्यकता है।

HTML कोड

<ion-nav-bar>
   <button ng-click = "setNavTitle('title')">
      Set title to banana!
   </button>
</ion-nav-bar>

नियंत्रक कोड

$scope.setNavTitle = function(title) {
   $ionicNavBarDelegate.title(title);
}

$ionicNavBarDelegateसेवा के अन्य उपयोगी तरीके हैं। इनमें से कुछ विधियाँ निम्न तालिका में सूचीबद्ध हैं।

$ IonicNavBarDelegate के लिए तरीके

तरीका पैरामीटर प्रकार विस्तार
संरेखित (पैरामीटर) केंद्र, बाएँ, दाएँ तार शीर्षक संरेखित करने के लिए उपयोग किया जाता है।
showBackButton (पैरामीटर) प्रदर्शन बूलियन बैक बटन दिखाने या छिपाने के लिए उपयोग किया जाता है।
शीर्षक (पैरामीटर) शीर्षक तार नया शीर्षक दिखाते थे।

ट्रैकिंग इतिहास

आप पिछले, वर्तमान और आगे के दृश्यों का इतिहास ट्रैक कर सकते हैं $ionicHistoryसर्विस। निम्न तालिका इस सेवा के सभी तरीकों को दिखाती है।

$ आयनिकहिस्टर के लिए तरीके

तरीका पैरामीटर प्रकार विस्तार
इतिहास देखे / वस्तु ऐप दृश्य इतिहास डेटा लौटाता है।
वर्तमान दृश्य() / वस्तु वर्तमान दृश्य लौटाता है।
शीर्षक (पैरामीटर) शीर्षक तार उस दृश्य की आईडी लौटाता है जो वर्तमान दृश्य का जनक है।
currentTitle (पैरामीटर) वैल तार वर्तमान दृश्य का शीर्षक लौटाता है। इसे नया सेट करके अपडेट किया जा सकता हैval मूल्य।
पीछे का दृश्य() / तार पिछला पिछला दृश्य लौटाता है।
backTitle () / तार अंतिम बैक व्यू का शीर्षक देता है।
forwardView () / वस्तु अंतिम फ़ॉरवर्ड दृश्य लौटाता है।
currentStateName () / तार वर्तमान स्थिति का नाम लौटाता है।
वापस जाओ() backCount संख्या वापस जाने के लिए कितने दृश्य निर्धारित करते थे। संख्या नकारात्मक होनी चाहिए। यदि यह सकारात्मक है या शून्य है तो इसका कोई प्रभाव नहीं पड़ेगा।
इतिहास मिटा दें() / / पूरे इतिहास को देखने के लिए उपयोग किया जाता है।
कैश को साफ़ करें() / वादा सभी कैश्ड दृश्यों को साफ़ करने के लिए उपयोग किया जाता है।
nextViewOptions () / वस्तु अगले दृश्य के विकल्प सेट करता है। अधिक जानकारी के लिए आप निम्न उदाहरण देख सकते हैं।

nextViewOptions() विधि में निम्नलिखित तीन विकल्प उपलब्ध हैं।

  • disableAnimate का उपयोग अगले दृश्य परिवर्तन के एनीमेशन को अक्षम करने के लिए किया जाता है।

  • disableBack अशक्त करने के लिए वापस दृश्य सेट करेगा।

  • historyRoot अगले दृश्य को रूट दृश्य के रूप में सेट करेगा।

$ionicHistory.nextViewOptions({
   disableAnimate: true,
   disableBack: true
});