आयनिक - जावास्क्रिप्ट पॉपओवर
यह एक ऐसा दृश्य है जो नियमित दृश्य के ऊपर दिखाई देगा।
पॉपओवर का उपयोग करना
एक पॉपओवर का उपयोग करके बनाया जा सकता है ion-popover-viewतत्व। इस तत्व को HTML टेम्पलेट और में जोड़ा जाना चाहिए$ionicPopover सेवा को नियंत्रक में इंजेक्ट करने की आवश्यकता है।
पॉपओवर जोड़ने के तीन तरीके हैं। पहला वाला हैfromTemplateविधि, जो इनलाइन टेम्पलेट का उपयोग करने की अनुमति देता है। पॉपओवर जोड़ने का दूसरा और तीसरा तरीका उपयोग करना हैfromTemplateUrl तरीका।
आइए हम समझते हैं fromtemplate तरीका नीचे बताया गया है।
Fromtemplate विधि के लिए नियंत्रक कोड
.controller('DashCtrl', function($scope, $ionicLoading, $ionicPopover) {
// .fromTemplate() method
var template = '<ion-popover-view>' + '<ion-header-bar>' +
'<h1 class = "title">Popover Title</h1>' +
'</ion-header-bar>'+ '<ion-content>' +
'Popover Content!' + '</ion-content>' + '</ion-popover-view>';
$scope.popover = $ionicPopover.fromTemplate(template, {
scope: $scope
});
$scope.openPopover = function($event) {
$scope.popover.show($event);
};
$scope.closePopover = function() {
$scope.popover.hide();
};
//Cleanup the popover when we're done with it!
$scope.$on('$destroy', function() {
$scope.popover.remove();
});
// Execute action on hide popover
$scope.$on('popover.hidden', function() {
// Execute action
});
// Execute action on remove popover
$scope.$on('popover.removed', function() {
// Execute action
});
})
जैसा कि ऊपर चर्चा की गई है, पॉपओवर जोड़ने का दूसरा और तीसरा तरीका उपयोग करना है fromTemplateUrlतरीका। नियंत्रक कोड को छोड़कर दोनों तरीकों के लिए समान होगाfromTemplateUrl मूल्य।
यदि HTML एक मौजूदा टेम्पलेट में जोड़ा जाता है, तो URL होगा popover.html। यदि हम HTML को टेम्प्लेट फ़ोल्डर में रखना चाहते हैं, तो URL बदल जाएगाtemplates/popover.html।
दोनों उदाहरण नीचे दिए गए हैं।
FromTemplateUrl के लिए नियंत्रक कोड
.controller('MyCtrl', function($scope, $ionicPopover) {
$ionicPopover.fromTemplateUrl('popover.html', {
scope: $scope
}).then(function(popover) {
$scope.popover = popover;
});
$scope.openPopover = function($event) {
$scope.popover.show($event);
};
$scope.closePopover = function() {
$scope.popover.hide();
};
//Cleanup the popover when we're done with it!
$scope.$on('$destroy', function() {
$scope.popover.remove();
});
// Execute action on hide popover
$scope.$on('popover.hidden', function() {
// Execute action
});
// Execute action on remove popover
$scope.$on('popover.removed', function() {
// Execute action
});
})
अब, हम जोड़ देंगे script HTML फ़ाइल के लिए टेम्पलेट के साथ, जिसे हम पॉपओवर फ़ंक्शन को कॉल करने के लिए उपयोग कर रहे हैं।
मौजूदा HTML फ़ाइल से HTML कोड
<script id = "popover.html" type = "text/ng-template">
<ion-popover-view>
<ion-header-bar>
<h1 class = "title">Popover Title</h1>
</ion-header-bar>
<ion-content>
Popover Content!
</ion-content>
</ion-popover-view>
</script>
अगर हम एक अलग फाइल के रूप में HTML बनाना चाहते हैं, तो हम एक नई HTML फाइल बना सकते हैं templates फ़ोल्डर और उसी कोड का उपयोग करें जैसा हमने उपर्युक्त उदाहरण में उपयोग किया था script टैग।
नई बनाई गई HTML फ़ाइल इस प्रकार है।
<ion-popover-view>
<ion-header-bar>
<h1 class = "title">Popover Title</h1>
</ion-header-bar>
<ion-content>
Popover Content!
</ion-content>
</ion-popover-view>
आखिरी चीज जो हमें चाहिए वह है एक बटन बनाना जो पॉपओवर दिखाने के लिए क्लिक किया जाएगा।
<button class = "button" ng-click = "openPopover($event)">Add Popover</button>
ऊपर दिए गए उदाहरणों में से हम जो भी रास्ता चुनेंगे, आउटपुट हमेशा वही रहेगा।
निम्न तालिका से पता चलता है $ionicPopover जिन तरीकों का इस्तेमाल किया जा सकता है।
तरीका | विकल्प | प्रकार | विस्तार |
---|---|---|---|
प्रारंभ (विकल्प) | स्कोप, फ़ोकस फ़र्स्ट, बैकड्रॉप क्लिकटोज़, हार्डवेयरबैकबटन क्लोज़ | ऑब्जेक्ट, बूलियन, बूलियन, बूलियन | Scopeपॉपओवर में कस्टम स्कोप पास करने के लिए उपयोग किया जाता है। डिफ़ॉल्ट $ rootScope है।focusFirstInput का उपयोग पॉपओवर के पहले इनपुट को फोकस करने के लिए किया जाता है। backdropClickToClose पृष्ठभूमि को क्लिक करते समय पॉपओवर को बंद करने के लिए उपयोग किया जाता है। hardwareBackButtonClose जब हार्डवेयर बैक बटन दबाया जाता है तो पॉपओवर को बंद करने के लिए उपयोग किया जाता है। |
दिखाने ($ घटना) | $ घटना | वादा | जब पॉपओवर पूरा हो रहा है तब हल किया गया। |
छिपाना() | / | वादा | हल हो गया जब पॉपओवर को छुपाया गया। |
हटाना() | / | वादा | जब पॉपओवर समाप्त हो रहा है तब हल किया गया। |
दिखाया गया है() | / | बूलियन | अगर यह नहीं दिखाया गया है या झूठ दिखाया गया है तो सही है। |