आयनिक - त्वरित गाइड

Ionic एक फ्रंट-एंड HTML फ्रेमवर्क है, जो सबसे ऊपर बना है AngularJS तथा Cordova। उनके आधिकारिक दस्तावेज के अनुसार, इस आयोनिक ओपन सोर्स फ्रेमवर्क की परिभाषा इस प्रकार है -

आयोनिक एक है HTML5 Mobile App Development Frameworkहाइब्रिड मोबाइल एप्लिकेशन बनाने पर लक्षित। Ionic को फ्रंट-एंड यूआई फ्रेमवर्क के रूप में सोचें जो आपके लुक और फील को हैंडल करता है और यूआई आपके ऐप्पल को मजबूर करने की आवश्यकता है। "देशी के लिए बूटस्ट्रैप" की तरह, लेकिन सामान्य देशी मोबाइल घटकों की एक विस्तृत श्रृंखला के लिए समर्थन के साथ, चालाक एनिमेशन और एक सुंदर डिजाइन।

आयनिक फ्रेमवर्क सुविधाएँ

Ionic की सबसे महत्वपूर्ण विशेषताएं निम्नलिखित हैं -

  • AngularJS - Ionic मोबाइल उपकरणों के लिए अनुकूलित समृद्ध एकल पृष्ठ अनुप्रयोगों के निर्माण के लिए AngularJS MVC वास्तुकला का उपयोग कर रहा है।

  • CSS components- देशी देखो और महसूस के साथ, ये घटक लगभग सभी तत्वों की पेशकश करते हैं जिनकी एक मोबाइल एप्लिकेशन को आवश्यकता होती है। अपने स्वयं के डिजाइनों को समायोजित करने के लिए घटकों की डिफ़ॉल्ट स्टाइल को आसानी से ओवरराइड किया जा सकता है।

  • JavaScript components - ये घटक उन सभी मोबाइल तत्वों को कवर करने के लिए जावास्क्रिप्ट कार्यों के साथ CSS घटकों का विस्तार कर रहे हैं जो केवल HTML और CSS के साथ नहीं किया जा सकता है।

  • Cordova Plugins - Apache Cordova plugins जावास्क्रिप्ट कोड जावास्क्रिप्ट कोड के साथ देशी डिवाइस कार्यों का उपयोग करने के लिए आवश्यक प्रदान करते हैं।

  • Ionic CLI - यह NodeJS उपयोगिता है, जो ईओण अनुप्रयोगों को शुरू करने, निर्माण, चलाने और अनुकरण करने के लिए आदेशों के साथ संचालित है।

  • Ionic View - देशी उपकरणों पर अपने आवेदन को अपलोड करने, साझा करने और परीक्षण करने के लिए बहुत उपयोगी मंच।

  • Licence - Ionic MIT लाइसेंस के तहत जारी किया गया है।

आयोनिक फ्रेमवर्क के फायदे

निम्नलिखित सबसे आम तौर पर ज्ञात आयोनिक फ्रेमवर्क के कुछ फायदे हैं -

  • आयनिक का उपयोग हाइब्रिड ऐप डेवलपमेंट के लिए किया जाता है। इसका मतलब यह है कि आप अपने अनुप्रयोगों को आईओएस, एंड्रॉइड, विंडोज फोन और फ़ायरफ़ॉक्स ओएस के लिए पैकेज कर सकते हैं, जो आपको बहुत सारे काम के समय बचा सकता है।

  • अपने ऐप को शुरू करना बहुत आसान है क्योंकि आयोनिक सरल लेआउट के साथ उपयोगी पूर्व-निर्मित ऐप सेटअप प्रदान करता है।

  • एप्लिकेशन बहुत साफ और मॉड्यूलर तरीके से बनाए गए हैं, इसलिए यह बहुत ही रखरखाव योग्य और अद्यतन करने में आसान है।

  • Ionic Developers टीम के Google Developers Team के साथ बहुत अच्छे संबंध हैं और वे फ्रेमवर्क को बेहतर बनाने के लिए मिलकर काम कर रहे हैं। अपडेट नियमित रूप से सामने आ रहे हैं और जरूरत पड़ने पर आयोनिक सपोर्ट ग्रुप हमेशा मदद के लिए तैयार रहता है।

आयनिक फ्रेमवर्क सीमाएँ

निम्नलिखित सबसे महत्वपूर्ण Ionic फ्रेमवर्क सीमाएँ हैं -

  • परीक्षण मुश्किल हो सकता है क्योंकि ब्राउज़र हमेशा आपको फोन पर्यावरण के बारे में सही जानकारी नहीं देता है। वहाँ कई अलग अलग उपकरणों के साथ ही प्लेटफार्मों हैं और आप आमतौर पर उनमें से ज्यादातर को कवर करने की जरूरत है।

  • विभिन्न देशी कार्यात्मकताओं को संयोजित करना कठिन हो सकता है। ऐसे कई उदाहरण होंगे जहां आप प्लगइन संगतता मुद्दों में भाग लेंगे, जो उन त्रुटियों को बनाने की ओर ले जाता है जो डीबग करना कठिन हैं।

  • हाइब्रिड ऐप्स देशी की तुलना में धीमे होते हैं। हालाँकि, चूंकि मोबाइल प्रौद्योगिकियां तेजी से सुधार कर रही हैं, इसलिए यह भविष्य में कोई समस्या नहीं होगी।

अगले अध्याय में, हम आयोनिक ओपन सोर्स फ्रेमवर्क के पर्यावरण सेटअप को समझेंगे।

यह अध्याय आपको दिखाएगा कि Ionic फ्रेमवर्क के साथ कैसे शुरू किया जाए। निम्न तालिका में आयनिक के साथ शुरू करने के लिए आवश्यक घटकों की सूची है।

अनु क्रमांक। सॉफ्टवेयर और विवरण
1

NodeJS

यह आयोनिक का उपयोग करके मोबाइल ऐप बनाने के लिए आवश्यक आधार प्लेटफ़ॉर्म है। आप हमारे NodeJS पर्यावरण सेटअप में NodeJS की स्थापना पर विस्तार से जान सकते हैं । सुनिश्चित करें कि आपने NpmJS स्थापित करते समय npm भी स्थापित किया है।

2

Android SDK

यदि आप विंडोज प्लेटफॉर्म पर काम करने जा रहे हैं और एंड्रॉइड प्लेटफॉर्म के लिए अपने एप्लिकेशन विकसित कर रहे हैं, तो आपके पास अपनी मशीन पर एंड्रॉइड एसडीके सेटअप होना चाहिए। निम्न लिंक में Android पर्यावरण सेटअप पर विस्तृत जानकारी है ।

3

XCode

यदि आप मैक प्लेटफ़ॉर्म पर काम करने जा रहे हैं और आईओएस प्लेटफ़ॉर्म के लिए अपने ऐप विकसित कर रहे हैं, तो आपके पास अपनी मशीन पर XCode सेटअप होना चाहिए। निम्न लिंक में iOS पर्यावरण सेटअप पर विस्तृत जानकारी है ।

4

cordova and Ionic

ये मुख्य एसडीके हैं जिन्हें आयोनिक के साथ काम करना शुरू करना आवश्यक है। यह अध्याय बताता है कि आयोनिक को सरल चरण में कैसे सेट किया जाए, यह मानते हुए कि आपके पास पहले से ही आवश्यक सेटअप है जैसा कि ऊपर दी गई तालिका में बताया गया है।

कॉर्डोवा और आयोनिक स्थापित करना

हम इस ट्यूटोरियल के लिए विंडोज कमांड प्रॉम्प्ट का उपयोग करेंगे। उसी चरण को OSX टर्मिनल पर लागू किया जा सकता है। कॉर्डोवा और आयोनिक स्थापित करने के लिए अपनी कमांड विंडो खोलें -

C:\Users\Username> npm install -g cordova ionic

ऐप्स बनाना

Ionic में एप्लिकेशन बनाते समय, आप निम्न तीन विकल्पों में से चुन सकते हैं -

  • टैब ऐप
  • ब्लैंक ऐप
  • साइड मेनू ऐप

अपनी कमांड विंडो में, वह फ़ोल्डर खोलें जहाँ आप ऐप बनाना चाहते हैं और नीचे दिए गए विकल्पों में से एक को आज़माएँ।

टैब ऐप

यदि आप ईओण टैब टेम्प्लेट का उपयोग करना चाहते हैं, तो ऐप टैब मेनू, हेडर और उपयोगी स्क्रीन और फ़ंक्शंस की एक जोड़ी के साथ बनाया जाएगा। यह डिफ़ॉल्ट आयोनिक टेम्प्लेट है। अपनी कमांड विंडो खोलें और चुनें कि आप अपना ऐप कहां बनाना चाहते हैं।

C:\Users\Username> cd Desktop

यह कमांड कार्यशील निर्देशिका को बदल देगा। ऐप डेस्कटॉप पर बनाया जाएगा।

C:\Users\Username\Desktop> ionic start myApp tabs

ईओण का Start कमांड एक फ़ोल्डर बनाएगा जिसका नाम है myApp और Ionic फ़ाइलों और फ़ोल्डरों को सेटअप करें।

C:\Users\Username\Desktop> cd myApp

अब, हम एक्सेस करना चाहते हैं myAppफ़ोल्डर जो हमने अभी बनाया है। यह हमारा रूट फोल्डर है।

आइए अब हम एंड्रॉइड प्लेटफ़ॉर्म के लिए कॉर्डोवा प्रोजेक्ट को जोड़ते हैं और साथ ही बेसिक कॉर्डोवा प्लगइन्स इंस्टॉल करते हैं। निम्नलिखित कोड हमें एंड्रॉइड एमुलेटर या डिवाइस पर ऐप चलाने की अनुमति देता है।

C:\Users\Username\Desktop\myApp> ionic platform add android

अगला कदम ऐप का निर्माण करना है। यदि आपको निम्न कमांड चलाने के बाद त्रुटियों का निर्माण होता है, तो आपने शायद Android SDK और उसकी निर्भरता को स्थापित नहीं किया है।

C:\Users\Username\Desktop\myApp> ionic build android

स्थापना प्रक्रिया का अंतिम चरण आपके ऐप को चलाना है, जो मोबाइल डिवाइस को चालू करेगा, यदि जुड़ा हुआ है, या डिफ़ॉल्ट एमुलेटर, यदि कोई उपकरण जुड़ा नहीं है। Android डिफ़ॉल्ट एमुलेटर धीमा है, इसलिए मैं आपको Genymotion या कुछ अन्य लोकप्रिय एंड्रॉइड एमुलेटर स्थापित करने का सुझाव देता हूं ।

C:\Users\Username\Desktop\myApp> ionic run android

यह नीचे दिए गए परिणाम का उत्पादन करेगा, जो एक आयोनिक टैब्स ऐप है।

ब्लैंक ऐप

यदि आप स्क्रैच से शुरू करना चाहते हैं, तो आप आयोनिक खाली टेम्पलेट स्थापित कर सकते हैं। हम उन्हीं चरणों का उपयोग करेंगे जिनके बारे में ऊपर बताया गया हैionic start myApp blank के बजाय ionic start myApp tabs निम्नलिखित नुसार।

C:\Users\Username\Desktop> ionic start myApp blank

आयनिक Start कमांड एक फ़ोल्डर बनाएगा जिसका नाम है myApp और Ionic फ़ाइलों और फ़ोल्डरों को सेटअप करें।

C:\Users\Username\Desktop> cd myApp

आइए हम एंड्रॉइड प्लेटफ़ॉर्म के लिए कॉर्डोवा प्रोजेक्ट को जोड़ते हैं और ऊपर बताए अनुसार बेसिक कॉर्डोवा प्लगइन्स इंस्टॉल करते हैं।

C:\Users\Username\Desktop\myApp>ionic platform add android

अगला कदम हमारे ऐप का निर्माण करना है -

C:\Users\Username\Desktop\myApp> ionic build android

अंत में, हम निम्नलिखित कोड के साथ ऐप शुरू करेंगे -

C:\Users\Username\Desktop\myApp> ionic run android

यह निम्नलिखित परिणाम का उत्पादन करेगा, जो एक आयोनिक ब्लैंक ऐप है।

साइड मेनू ऐप

तीसरा टेम्पलेट जिसे आप उपयोग कर सकते हैं वह है साइड मेनू टेम्पलेट। चरण पिछले दो टेम्पलेट्स के समान हैं; हम सिर्फ जोड़ देंगेsidemenu नीचे दिए गए कोड में दिखाए गए अनुसार हमारे ऐप को शुरू करते समय।

C:\Users\Username\Desktop> ionic start myApp sidemenu

आयनिक Start कमांड एक फ़ोल्डर बनाएगा जिसका नाम है myApp और Ionic फ़ाइलों और फ़ोल्डरों को सेटअप करें।

C:\Users\Username\Desktop> cd myApp

आइए हम एंड्रॉइड प्लेटफ़ॉर्म के लिए कॉर्डोवा प्रोजेक्ट को जोड़ते हैं और नीचे दिए गए कोड के साथ बुनियादी कॉर्डोवा प्लगइन्स इंस्टॉल करते हैं।

C:\Users\Username\Desktop\myApp> ionic platform add android

अगला कदम निम्नलिखित कोड के साथ हमारे ऐप का निर्माण करना है।

C:\Users\Username\Desktop\myApp> ionic build android

अंत में, हम नीचे दिए गए कोड के साथ ऐप शुरू करेंगे।

C:\Users\Username\Desktop\myApp> ionic run android

यह निम्नलिखित परिणाम का उत्पादन करेगा, जो एक आयोनिक साइड मेनू ऐप है।

ब्राउज़र में टेस्ट ऐप

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

C:\Users\Username\Desktop\myApp> ionic serve

उपरोक्त कमांड वेब ब्राउज़र में आपका ऐप खोल देगा। Google Chrome मोबाइल विकास परीक्षण के लिए डिवाइस मोड कार्यक्षमता प्रदान करता है। दबाएँF12 डेवलपर कंसोल तक पहुंचने के लिए।

कंसोल विंडो क्लिक के ऊपरी बाएं कोने में "टॉगल डिवाइस मोड" आइकन है। अगला कदम शीर्ष दाएं कोने में "डॉक टू राइट" आइकन पर क्लिक करना होगा। एक बार पृष्ठ ताज़ा होने के बाद, आपको वेब ब्राउज़र पर परीक्षण के लिए तैयार होना चाहिए।

प्रोजेक्ट फ़ोल्डर संरचना

Ionic सभी प्रकार के ऐप्स के लिए निम्न निर्देशिका संरचना बनाता है। किसी भी Ionic डेवलपर के लिए यह महत्वपूर्ण है कि वह प्रत्येक निर्देशिका के उद्देश्य और नीचे उल्लिखित फाइलों को समझे -

आइए हम ऊपर की छवि में दिखाए गए प्रोजेक्ट फ़ोल्डर संरचना में उपलब्ध सभी फ़ोल्डरों और फाइलों की त्वरित समझ रखते हैं।

  • Hooks- हुक ऐसी स्क्रिप्ट हैं जिन्हें बिल्ड प्रक्रिया के दौरान ट्रिगर किया जा सकता है। वे आमतौर पर कॉर्डोवा कमांड अनुकूलन के लिए और स्वचालित प्रक्रियाओं के निर्माण के लिए उपयोग किए जाते हैं। हम इस ट्यूटोरियल के दौरान इस फ़ोल्डर का उपयोग नहीं करेंगे।

  • Platforms- यह वह फ़ोल्डर है जहां Android और IOS प्रोजेक्ट बनाए जाते हैं। आपको विकास के दौरान कुछ प्लेटफ़ॉर्म विशिष्ट समस्याओं का सामना करना पड़ सकता है, जिनके लिए इन फ़ाइलों की आवश्यकता होगी, लेकिन आपको उन्हें ज्यादातर समय बरकरार रखना चाहिए।

  • Plugins- इस फोल्डर में कॉर्डोवा प्लगइन्स हैं। जब आप शुरू में एक आयोनिक ऐप बनाते हैं, तो कुछ प्लगइन्स इंस्टॉल हो जाएंगे। हम आपको दिखाएंगे कि हमारे बाद के अध्यायों में कॉर्डोवा प्लगइन्स कैसे स्थापित करें।

  • Resources - इस फ़ोल्डर का उपयोग आपके प्रोजेक्ट में आइकन और स्प्लैश स्क्रीन जैसे संसाधनों को जोड़ने के लिए किया जाता है।

  • Scss- चूँकि Sonic का निर्माण Sass के साथ हुआ है, यह वह फ़ोल्डर है जहाँ आपकी Sass फ़ाइल स्थित है। प्रक्रिया को सरल बनाने के लिए, हम इस ट्यूटोरियल के लिए सैस का उपयोग नहीं करेंगे। हमारी स्टाइलिंग CSS का उपयोग करके की जाएगी।

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

    • css फ़ोल्डर, जहाँ आप अपनी CSS स्टाइलिंग लिखेंगे।

    • img छवियों को संग्रहीत करने के लिए फ़ोल्डर।

    • jsफ़ोल्डर जिसमें ऐप्स मुख्य कॉन्फ़िगरेशन फ़ाइल (app.js) और AngularJS घटक (नियंत्रक, सेवाएं, निर्देश) हैं। आपका सभी जावास्क्रिप्ट कोड इन फ़ोल्डरों के अंदर होगा।

    • libs फ़ोल्डर, जहाँ आपके पुस्तकालयों को रखा जाएगा।

    • templates आपकी HTML फ़ाइलों के लिए फ़ोल्डर।

    • Index.html अपने ऐप के लिए एक शुरुआती बिंदु के रूप में।

  • Other Files - चूंकि यह एक शुरुआती ट्यूटोरियल है, हम सिर्फ कुछ अन्य महत्वपूर्ण फाइलों और उनके उद्देश्यों का भी उल्लेख करेंगे।

    • .bowerrc बोवर कॉन्फ़िगरेशन फ़ाइल है।

    • .editorconfig संपादक कॉन्फ़िगरेशन फ़ाइल है।

    • .gitignore का उपयोग यह निर्देश देने के लिए किया जाता है कि ऐप के किस भाग को अनदेखा किया जाए जब आप अपने ऐप को Git रिपॉजिटरी में धकेलना चाहते हैं।

    • bower.json यदि आप बोवर पैकेज प्रबंधक का उपयोग करने के लिए चुनते हैं, तो इसमें बोवर घटक और निर्भरताएं शामिल होंगी।

    • gulpfile.js gulp कार्य प्रबंधक का उपयोग करके स्वचालित कार्य बनाने के लिए उपयोग किया जाता है।

    • config.xml कॉर्डोवा कॉन्फ़िगरेशन फ़ाइल है।

    • package.json इसमें उन ऐप्स, उनकी निर्भरता और प्लगइन्स की जानकारी होती है जो NPM पैकेज मैनेजर का उपयोग करके इंस्टॉल किए जाते हैं।

अगले अध्याय में, हम आयनिक ओपन सोर्स फ्रेमवर्क में उपलब्ध विभिन्न रंगों पर चर्चा करेंगे।

इससे पहले कि हम ईओण ढांचे में उपलब्ध वास्तविक तत्वों के साथ शुरू करें, आइए हम इस बारे में थोड़ी समझ रखें कि आयन विभिन्न रंगों के लिए रंगों का उपयोग कैसे करता है।

आयनिक रंग कक्षाएं

आयोनिक फ्रेमवर्क हमें एक सेट देता है nine predefined color classes। आप इन रंगों का उपयोग कर सकते हैं या अपनी स्टाइल के साथ इसे ओवरराइड कर सकते हैं।

निम्न तालिका Ionic द्वारा प्रदान किए गए नौ रंगों के डिफ़ॉल्ट सेट को दिखाती है। हम इस ट्यूटोरियल में विभिन्न आयोनिक तत्वों की स्टाइलिंग के लिए इन रंगों का उपयोग करेंगे। अभी के लिए, आप नीचे दिखाए गए अनुसार सभी रंगों की जाँच कर सकते हैं -

कक्षा विवरण परिणाम
रोशनी सफेद रंग के लिए इस्तेमाल किया जाना है  
स्थिर हल्के भूरे रंग के लिए उपयोग किया जाना है  
सकारात्मक नीले रंग के लिए इस्तेमाल किया जाना है  
शांत हल्के नीले रंग के लिए इस्तेमाल किया जाना है  
संतुलित हरे रंग के लिए इस्तेमाल किया जाना है  
सक्रिय पीले रंग के लिए इस्तेमाल किया जाना है  
मुखर लाल रंग के लिए इस्तेमाल किया जाना है  
शाही बैंगनी रंग के लिए इस्तेमाल किया जाना है  
अंधेरा काले रंग के लिए इस्तेमाल किया जाना है  

आयोनिक रंग उपयोग

आयनिक प्रत्येक तत्व के लिए विभिन्न वर्गों का उपयोग करता है। उदाहरण के लिए, एक हेडर तत्व होगाbar कक्षा और एक बटन एक होगा buttonकक्षा। उपयोग को सरल बनाने के लिए, हम एक रंग नाम में तत्व वर्ग को उपसर्ग करके विभिन्न रंगों का उपयोग करते हैं।

उदाहरण के लिए, नीले रंग का हेडर बनाने के लिए, हम एक का उपयोग करेंगे bar-calm निम्नानुसार है -

<div class = "bar bar-header bar-calm">
   ...
</div>

इसी तरह, एक ग्रे रंग बटन बनाने के लिए, हम उपयोग करेंगे button-stable निम्नानुसार वर्ग।

<div class = "button button-stable">
   ...
</div>

आप किसी अन्य CSS क्लास की तरह Ionic कलर क्लास का भी उपयोग कर सकते हैं। अब हम एक संतुलित (हरा) और एक ऊर्जावान (पीला) रंग के साथ दो पैराग्राफों को स्टाइल करेंगे।

<p class = "balanced">Paragraph 1...</p>
<p class = "energized">Paragraph 2...</p>

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

हम बाद के अध्यायों में विस्तार से चर्चा करेंगे, जब हम विभिन्न वर्गों का उपयोग करके अलग-अलग तत्व बनाते हैं।

सीएसएस के साथ रंग अनुकूलित

जब आप सीएसएस का उपयोग करके कुछ आयोनिक डिफ़ॉल्ट रंगों को बदलना चाहते हैं, तो आप इसे संपादित करके कर सकते हैं lib/css/ionic.cssफ़ाइल। कुछ मामलों में, यह दृष्टिकोण बहुत उत्पादक नहीं है क्योंकि हर तत्व (हेडर, बटन, पाद ...) स्टाइल के लिए अपनी कक्षाओं का उपयोग करता है।

इसलिए, यदि आप "प्रकाश" वर्ग के रंग को नारंगी में बदलना चाहते हैं, तो आपको उन सभी तत्वों की खोज करनी होगी जो इस वर्ग का उपयोग करते हैं और इसे बदलते हैं। यह तब उपयोगी होता है जब आप किसी एक तत्व का रंग बदलना चाहते हैं, लेकिन सभी तत्वों के रंग बदलने के लिए बहुत व्यावहारिक नहीं है क्योंकि यह बहुत अधिक समय का उपयोग करेगा।

SASS का उपयोग करके रंग अनुकूलित करना

SASS (जिसका संक्षिप्त रूप है - Syntactically Awesome Style Sheet) एक बार में सभी तत्वों के लिए रंग बदलने का एक आसान तरीका प्रदान करता है। यदि आप SASS का उपयोग करना चाहते हैं, तो कमांड विंडो में अपना प्रोजेक्ट खोलें और टाइप करें -

C:\Users\Username\Desktop\tutorialApp> ionic setup sass

यह आपके प्रोजेक्ट के लिए SASS सेट करेगा। अब आप डिफ़ॉल्ट रंग बदल कर खोल सकते हैंscss/ionic.app.scss इस लाइन से पहले फाइल और फिर निम्नलिखित कोड टाइप करें - @import "www/lib/ionic/scss/ionic";

हम संतुलित रंग को गहरे नीले और ऊर्जा वाले रंग को नारंगी में बदल देंगे। दो पैराग्राफ जो हमने ऊपर इस्तेमाल किए थे अब गहरे नीले और नारंगी हैं।

$balanced: #000066 !default; $energized: #FFA500 !default;

अब, यदि आप निम्नलिखित उदाहरण का उपयोग करते हैं -

<p class = "balanced">Paragraph 1...</p>
<p class = "energized">Paragraph 2...</p>

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

इन वर्गों का उपयोग करने वाले सभी आयनिक तत्व गहरे नीले और नारंगी में बदल जाएंगे। ध्यान रखें कि आपको आयोनिक डिफ़ॉल्ट रंग वर्गों का उपयोग करने की आवश्यकता नहीं है। आप हमेशा अपनी इच्छानुसार तत्वों को स्टाइल कर सकते हैं।

महत्वपूर्ण लेख

www/css/style.cssआपके द्वारा SASS स्थापित करने के बाद फ़ाइल को index.html के हेडर से हटा दिया जाएगा। यदि आप अभी भी इसका उपयोग करना चाहते हैं, तो आपको इसे मैन्युअल रूप से लिंक करना होगा। Index.html खोलें और फिर हेडर के अंदर निम्न कोड जोड़ें।

<link href = "css/style.css" rel = "stylesheet">

लगभग हर मोबाइल ऐप में कुछ मूलभूत तत्व होते हैं। आमतौर पर उन तत्वों में एक हेडर और एक पाद शामिल होता है जो स्क्रीन के ऊपर और नीचे के हिस्से को कवर करेगा। अन्य सभी तत्वों को इन दोनों के बीच रखा जाएगा। आयोनिक प्रदान करता हैion-content तत्व जो एक कंटेनर के रूप में कार्य करता है जो अन्य सभी तत्वों को लपेटेगा जो हम बनाना चाहते हैं।

इस कंटेनर में कुछ विशिष्ट विशेषताएं हैं, लेकिन चूंकि यह एक जावास्क्रिप्ट आधारित घटक है, जिसे हम इस ट्यूटोरियल के बाद के भाग में कवर करेंगे ।

<div class = "bar bar-header"> 
   <h1 class = "title">Header</h1> 
</div>
 
<div class = "list"> 
   <label class = "item item-input"> 
      <input type = "text" placeholder = "Placeholder 1" /> 
   </label>
   
   <label class = "item item-input"> 
      <input type = "text" placeholder = "Placeholder 2" /> 
   </label> 
</div>

<div class = "bar bar-footer"> 
   <h1 class = "title">Footer</h1> 
</div>

Ionic header barस्क्रीन के शीर्ष पर स्थित है। इसके शीर्ष पर शीर्षक, चिह्न, बटन या कुछ अन्य तत्व हो सकते हैं। हेडर की पूर्वनिर्धारित कक्षाएं हैं जिनका आप उपयोग कर सकते हैं। आप इस ट्यूटोरियल में इसे देख सकते हैं।

हैडर जोड़ना

आपके एप्लिकेशन में आपके द्वारा उपयोग की जा सकने वाली सभी सलाखों के लिए मुख्य वर्ग है bar। यह क्लास हमेशा आपके ऐप में सभी बार पर लागू होगी। सबbar subclasses उपसर्ग का उपयोग करेगा - bar

यदि आप हेडर बनाना चाहते हैं, तो आपको जोड़ना होगा bar-header अपने मुख्य के बाद barकक्षा। अपनी खोलोwww/index.html अपने अंदर हेडर क्लास को फ़ाइल करें और जोड़ें bodyटैग। हम में एक हेडर जोड़ रहे हैंindex.html body क्योंकि हम चाहते हैं कि यह ऐप में हर स्क्रीन पर उपलब्ध हो।

जबसे bar-header क्लास में डिफ़ॉल्ट (सफ़ेद) स्टाइल लागू है, हम इसके शीर्ष पर शीर्षक जोड़ देंगे, ताकि आप इसे अपनी बाकी स्क्रीन से अलग कर सकें।

<div class = "bar bar-header">
   <h1 class = "title">Header</h1>
</div>

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

हैडर रंग

यदि आप अपने हेडर को स्टाइल करना चाहते हैं, तो आपको बस इसमें उपयुक्त रंग वर्ग जोड़ना होगा। जब आप अपने तत्वों को स्टाइल करते हैं, तो आपको अपने मुख्य तत्व वर्ग को अपने रंग वर्ग में उपसर्ग के रूप में जोड़ना होगा। चूंकि हम हेडर बार को स्टाइल कर रहे हैं, इसलिए उपसर्ग वर्ग होगाbar और रंग वर्ग जिसे हम इस उदाहरण में उपयोग करना चाहते हैं positive (नीला)।

<div class = "bar bar-header bar-positive">
   <h1 class = "title">Header</h1>
</div>

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

आप अपनी पसंद का रंग देने के लिए निम्न नौ वर्गों में से किसी का भी उपयोग अपने ऐप हेडर में कर सकते हैं -

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

हैडर तत्व

हम हेडर के अंदर अन्य तत्वों को जोड़ सकते हैं। निम्नलिखित कोड एक जोड़ने के लिए एक उदाहरण हैmenu बटन और ए homeएक हेडर के अंदर बटन। हम अपने हेडर बटन के ऊपर आइकन भी जोड़ेंगे।

<div class = "bar bar-header bar-positive">
   <button class = "button icon ion-navicon"></button>
   <h1 class = "title">Header Buttons</h1>
   <button class = "button icon ion-home"></button>
</div>

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

उप हैडर

आप एक उप हेडर बना सकते हैं जो हेडर बार के ठीक नीचे स्थित होगा। निम्न उदाहरण दिखाएगा कि अपने ऐप में हेडर और सब हेडर कैसे जोड़ें। यहां, हमने "हेडर" (लाल) रंग वर्ग के साथ उप हेडर को स्टाइल किया है।

<div class = "bar bar-header bar-positive">
   <button class = "button icon ion-navicon"></button>
   <h1 class = "title">Header Buttons</h1>
   <button class = "button icon ion-home"></button>
</div>

<div class = "bar bar-subheader bar-assertive">
   <h2 class = "title">Sub Header</h2>
</div>

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

जब आपका मार्ग एप्लिकेशन स्क्रीन में से किसी में बदल जाता है, तो आप देखेंगे कि हेडर और उप हेडर कुछ सामग्री को कवर कर रहे हैं जैसा कि नीचे स्क्रीनशॉट में दिखाया गया है।

इसे ठीक करने के लिए आपको एक जोड़ने की आवश्यकता है ‘has-header’ या ए ‘has-subheader’ वर्ग के लिए ion-contentआपकी स्क्रीन के टैग। अपनी एक HTML फाइल खोलेंwww/templates और जोड़ें has-subheader वर्ग के लिए ion-content। यदि आप अपने ऐप में केवल हेडर का उपयोग करते हैं, तो आपको इसे जोड़ना होगाhas-header इसके बजाय कक्षा।

<ion-content class = "padding has-subheader">

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

Ionic footerएप्लिकेशन स्क्रीन के नीचे रखा गया है। फ़ुटर्स के साथ काम करना लगभग उसी तरह है जैसे हेडर के साथ काम करना।

पाद जोड़ना

ईओण पाद के लिए मुख्य वर्ग है bar(हेडर के समान ही)। जब आप अपने स्क्रीन पर पाद जोड़ना चाहते हैं, तो आपको जोड़ना होगाbar-footer मुख्य के बाद अपने तत्व के लिए वर्ग barकक्षा। चूंकि हम ऐप में हर स्क्रीन पर अपने फूटर का उपयोग करना चाहते हैं, इसलिए हम इसे जोड़ देंगेbody का index.htmlफ़ाइल। हम अपने पाद लेख के लिए भी शीर्षक जोड़ेंगे।

<div class = "bar bar-footer">
   <h1 class = "title">Footer</h1>
</div>

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

पाद रंग

यदि आप अपने पाद लेख की शैली बनाना चाहते हैं, तो आपको बस इसमें उपयुक्त रंग वर्ग जोड़ना होगा। जब आप अपने तत्वों को स्टाइल करते हैं, तो आपको अपने मुख्य तत्व वर्ग को अपने रंग वर्ग में एक उपसर्ग के रूप में जोड़ना होगा। चूँकि हम एक पाद पट्टी को स्टाइल कर रहे हैं, इसलिए उपसर्ग वर्ग a होगाbar और रंग वर्ग जिसे हम इस उदाहरण में उपयोग करना चाहते हैं assertive (लाल)।

<div class = "bar bar-footer bar-assertive">
   <h1 class = "title">Footer</h1>
</div>

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

आप अपनी पसंद का रंग देने के लिए निम्न नौ में से किसी भी वर्ग का उपयोग कर सकते हैं -

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

पाद तत्व

पाद में इसके अंदर तत्व हो सकते हैं। अधिकांश समय आपको एक पाद के अंदर आइकन के साथ बटन जोड़ने की आवश्यकता होगी।

जोड़ा गया पहला बटन हमेशा बाएं कोने में होगा। आखिरी वाले को दाईं ओर रखा जाएगा। बीच में बटन आपके पाद के बाईं ओर पहले वाले के बगल में रखे जाएंगे। निम्नलिखित उदाहरण में, आप यह भी देख सकते हैं कि हम इसका उपयोग करते हैंicon बटन के शीर्ष पर आइकन जोड़ने के लिए वर्ग।

<div class = "bar bar-footer bar-assertive">
   <button class = "button icon ion-navicon"></button>
   <button class = "button icon ion-home"></button>
   <button class = "button icon ion-star"></button>
   <button class = "button icon ion-checkmark-round"></button>
</div>

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

यदि आप अपने बटन को दाईं ओर ले जाना चाहते हैं तो आप जोड़ सकते हैं pull-right कक्षा।

<div class = "bar bar-footer bar-assertive">
   <button class = "button icon ion-navicon pull-right"></button>
</div>

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

आयनिक फ्रेमवर्क में कई प्रकार के बटन होते हैं और ये बटन सूक्ष्म रूप से एनिमेटेड होते हैं, जो ऐप का उपयोग करते समय उपयोगकर्ता के अनुभव को और बढ़ाता है। सभी बटन प्रकारों के लिए मुख्य वर्ग हैbutton। यह वर्ग हमेशा हमारे बटन पर लागू होगा, और हम उप-वर्गों के साथ काम करते समय इसे उपसर्ग के रूप में उपयोग करेंगे।

बटन को ब्लॉक करें

ब्लॉक बटन में हमेशा उनके मूल कंटेनर की 100% चौड़ाई होगी। उनके पास एक छोटी गद्दी भी होगी। आप उपयोग करेंगेbutton-blockब्लॉक बटन जोड़ने के लिए वर्ग। यदि आप पैडिंग को हटाना चाहते हैं, लेकिन पूरी चौड़ाई रखते हैं, तो आप इसका उपयोग कर सकते हैंbutton-full कक्षा।

निम्नलिखित दोनों वर्गों के उपयोग को दिखाने के लिए एक उदाहरण है -

<button class = "button button-block">
   button-block
</button>

<button class = "button button-full">
   button-full
</button>

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

बटन के आकार

बटन का आकार बदलने के लिए दो आयोनिक कक्षाएं हैं -

  • button-small तथा

  • button-large.

निम्नलिखित उनका उपयोग दिखाने के लिए एक उदाहरण है -

<button class = "button button-small">
   button-small
</button>

<button class = "button button-large">
   button-large
</button>

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

बटन रंग

यदि आप अपने बटन को स्टाइल करना चाहते हैं, तो आपको इसमें उपयुक्त रंग वर्ग जोड़ना होगा। जब आप अपने तत्वों को स्टाइल करते हैं, तो आपको अपने मुख्य तत्व वर्ग को अपने रंग वर्ग में एक उपसर्ग के रूप में जोड़ना होगा। चूँकि हम पाद पट्टी को स्टाइल कर रहे हैं, इसलिए उपसर्ग वर्ग a होगाbar और रंग वर्ग जिसे हम इस उदाहरण में उपयोग करना चाहते हैं assertive (लाल)।

<button class = "button button-assertive">
   button-assertive
</button>

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

अपनी पसंद का रंग देने के लिए आप निम्नलिखित नौ में से किसी भी वर्ग का उपयोग कर सकते हैं -

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

बटन की रूपरेखा

यदि आप अपने बटनों को पारदर्शी चाहते हैं, तो आप आवेदन कर सकते हैं button-outlineकक्षा। इस वर्ग के बटनों में एक रूपरेखा सीमा और एक पारदर्शी पृष्ठभूमि होगी।

बॉर्डर को बटन से हटाने के लिए, आप इसका उपयोग कर सकते हैं button-clearकक्षा। निम्न उदाहरण दिखाता है कि इन दो वर्गों का उपयोग कैसे किया जाए।

<button class = "button button-assertive button-outline">
   button-outline
</button>

<button class = "button button-assertive button-clear">
   button-clear
</button>

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

प्रतीक जोड़ना

जब आप अपने बटनों में आइकन जोड़ना चाहते हैं, तो सबसे अच्छा तरीका है iconकक्षा। आप आइकन को बटन के एक तरफ रख सकते हैंicon-left या icon-right। आप आमतौर पर अपने आइकन को एक तरफ स्थानांतरित करना चाहेंगे जब आपके पास नीचे बताए अनुसार आपके बटन के ऊपर कुछ पाठ हो।

<button class = "button icon ion-home">
</button>

<button class = "button icon icon-left ion-home">
   Home
</button>

<button class = "button icon icon-right ion-home">
   Home
</button>

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

बटन बार

यदि आप एक साथ दो बटन समूह बनाना चाहते हैं, तो आप इसका उपयोग कर सकते हैं button-barकक्षा। बटन डिफ़ॉल्ट रूप से समान आकार के होंगे।

<div class = "button-bar">
   <a class = "button button-positive">1</a>
   <a class = "button button-assertive">2</a>
   <a class = "button button-energized">3</a>
   <a class = "button">4</a>
</div>

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

Listsकिसी भी वेब या मोबाइल एप्लिकेशन के सबसे लोकप्रिय तत्वों में से एक हैं। उनका उपयोग आमतौर पर विभिन्न सूचनाओं को प्रदर्शित करने के लिए किया जाता है। उन्हें अलग-अलग मेनू, टैब बनाने या शुद्ध पाठ फ़ाइलों की एकरसता को तोड़ने के लिए अन्य HTML तत्वों के साथ जोड़ा जा सकता है। आयोनिक फ्रेमवर्क उनके उपयोग को आसान बनाने के लिए विभिन्न प्रकार की सूची प्रदान करता है।

आयोनिक सूची बनाना

हर सूची दो तत्वों के साथ बनाई गई है। जब आप एक मूल सूची बनाना चाहते हैं<ul> टैग की जरूरत है list वर्ग सौंपा, और अपने <li> टैग का उपयोग करेगा itemकक्षा। एक और दिलचस्प बात यह है कि आपको उपयोग करने की भी आवश्यकता नहीं है<ul>, <ol> तथा <li>आपकी सूचियों के लिए टैग। आप किसी भी अन्य तत्वों का उपयोग कर सकते हैं, लेकिन महत्वपूर्ण बात यह है कि जोड़ना हैlist तथा item उचित रूप से कक्षाएं।

<div class = "list">
   <div class = "item">Item 1</div>
   <div class = "item">Item 2</div>
   <div class = "item">Item 3</div>
</div>

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

इनसेट सूची

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

<div class = "list list-inset">
   <div class = "item">Item 1</div>
   <div class = "item">Item 2</div>
   <div class = "item">Item 3</div>
</div>

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

आइटम डिवाइडर

डिवाइडर का उपयोग कुछ तत्वों को तार्किक समूहों में व्यवस्थित करने के लिए किया जाता है। आयोनिक हमें देता हैitem-dividerइसके लिए क्लास करें। फिर से, अन्य सभी ईओण तत्वों की तरह, हमें बस इसे जोड़ने की आवश्यकता हैitem-divider कक्षा के बाद itemकक्षा। आइटम डिवाइडर एक सूची शीर्षलेख के रूप में उपयोगी होते हैं, क्योंकि उनमें डिफ़ॉल्ट रूप से अन्य सूची आइटम की तुलना में अधिक मजबूत स्टाइल होता है।

<div class = "list">
   <div class = "item item-divider">Item Divider 1</div>
   <div class = "item">Item 1</div>
   <div class = "item">Item 2</div>
   <div class = "item">Item 3</div>

   <div class = "item item-divider">Item Divider 2</div>
   <div class = "item">Item 4</div>
   <div class = "item">Item 5</div>
   <div class = "item">Item 6</div>
</div>

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

प्रतीक जोड़ना

हमने आपको पहले ही दिखाया था कि अपने बटनों में आइकन कैसे जोड़ें। सूची आइटम में आइकन जोड़ते समय, आपको यह चुनने की आवश्यकता होती है कि आप उन्हें किस पक्ष में रखना चाहते हैं। वहांitem-icon-left तथा item-icon-rightइसके लिए कक्षाएं। आप उन दो वर्गों को भी जोड़ सकते हैं, यदि आप दोनों तरफ अपने आइकॉन रखना चाहते हैं। अंत में, वहाँ हैitem-note अपने आइटम में एक पाठ नोट जोड़ने के लिए कक्षा।

<div class = "list">
   <div class = "item item-icon-left">
      <i class = "icon ion-home"></i>
      Left side Icon
   </div>

   <div class = "item item-icon-right">
      <i class = "icon ion-star"></i>
      Right side Icon
   </div>

   <div class = "item item-icon-left item-icon-right">
      <i class = "icon ion-home"></i>
      <i class = "icon ion-star"></i>
      Both sides Icons
   </div>
   
   <div class = "item item-icon-left">
      <i class = "icon ion-home"></i>
      <span class = "text-note">Text note</span>
   </div>
</div>

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

अवतारों और थंबनेल को जोड़ना

अवतार और थंबनेल समान हैं। मुख्य अंतर यह है कि अवतार थंबनेल से छोटे होते हैं। ये थंबनेल सूची आइटम की पूरी ऊंचाई को कवर कर रहे हैं, जबकि अवतार मध्यम आकार के चक्र चित्र हैं। जिन वर्गों का उपयोग किया जाता है वे हैंitem-avatar तथा item-thumbnail। आप यह भी चुन सकते हैं कि आप अपने अवतार और थंबनेल को किस पक्ष में रखना चाहते हैं, जैसा कि नीचे थंबनेल कोड उदाहरण में दिखाया गया है।

<div class = "list">
   <div class = "item item-avatar">
      <img src = "my-image.png">
      <h3>Avatar</h3>
   </div>

   <div class = "item item-thumbnail-left">
      <img src = "my-image.png">
      <h3>Thumbnail</h3>
   </div>
</div>

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

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

कार्ड जोड़ना

एक डिफ़ॉल्ट कार्ड को जोड़कर बनाया जा सकता है cardअपने तत्व के लिए वर्ग। कार्ड आमतौर पर सूची के साथ बनते हैंitemकक्षा। सबसे उपयोगी वर्ग में से एक हैitem-text-wrap। यह तब मदद करेगा जब आपके पास बहुत अधिक पाठ हो, इसलिए आप इसे अपने कार्ड के अंदर लपेटना चाहते हैं। निम्नलिखित उदाहरण में पहला कार्ड नहीं हैitem-text-wrap वर्ग सौंपा गया है, लेकिन दूसरा इसका उपयोग कर रहा है।

<div class = "card">
   <div class = "item">
      This is a Ionic card without item-text-wrap class.
   </div>
   
   <div class = "item item-text-wrap">
      This is a Ionic card with item-text-wrap class.
   </div>
</div>

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

कार्ड हैडर और पाद

पिछले अध्याय में, हम पहले ही चर्चा कर चुके हैं कि एप्लिकेशन का उपयोग कैसे करें item-dividerसमूह सूची के लिए वर्ग। कार्ड हेडर बनाने के लिए कार्ड के साथ काम करते समय यह वर्ग बहुत उपयोगी हो सकता है। उसी श्रेणी का उपयोग पाद लेख के लिए किया जा सकता है जैसा कि निम्नलिखित कोड में दिखाया गया है -

<div class = "card list">
   <div class = "item item-divider">
      Card header
   </div>
   
   <div class = "item item-text-wrap">
      Card text...
   </div>
   
   <div class = "item item-divider">
      Card Footer
   </div>
</div>

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

पूरा कार्ड

आप अपने कार्ड के शीर्ष पर कोई भी तत्व जोड़ सकते हैं। निम्नलिखित उदाहरण में, हम आपको दिखाएंगे कि कैसे उपयोग करना हैfull-image साथ में कक्षा item-body अपने कार्ड के अंदर एक अच्छी दिखने वाली विंडो वाली छवि प्राप्त करने के लिए।

<div class = "card">
   <div class = "item item-avatar">
      <img src = "my-image.png">
      <h2>Card Name</h2>
   </div>

   <div class = "item item-body">
      <img class = "full-image" src = "my-image.png">
      Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque eget 
      pharetra tortor. Proin quis eros imperdiet, facilisis nisi in, tincidunt orci. 
      Nam tristique elit massa, quis faucibus augue finibus ac.
   </div>
</div>

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

Ionic formsज्यादातर उपयोगकर्ताओं के साथ बातचीत और आवश्यक जानकारी एकत्र करने के लिए उपयोग किया जाता है। यह अध्याय विभिन्न पाठ इनपुट रूपों और हमारे बाद के अध्यायों में शामिल होगा, हम बताएंगे कि Ionic ढांचे का उपयोग करके अन्य रूप तत्वों का उपयोग कैसे किया जाए।

इनपुट फॉर्म का उपयोग करना

रूपों का उपयोग करने का सबसे अच्छा तरीका उपयोग करना है list तथा itemअपने मुख्य वर्गों के रूप में। आपके ऐप में आमतौर पर एक से अधिक फ़ॉर्म तत्व शामिल होंगे, इसलिए यह सूची के रूप में व्यवस्थित करने के लिए समझ में आता है। निम्नलिखित उदाहरण में, आप देख सकते हैं कि आइटम तत्व ए हैlabel टैग।

आप किसी भी अन्य तत्व का उपयोग कर सकते हैं, लेकिन एक लेबल आपके पाठ इनपुट पर ध्यान केंद्रित करने के लिए तत्व के किसी भी भाग पर टैप करने की क्षमता प्रदान करेगा। आप एक सेट कर सकते हैंplaceholderवह इनपुट टेक्स्ट से अलग दिखेगा और जैसे ही आप लिखना शुरू करेंगे, यह छिपा दिया जाएगा। आप इसे नीचे दिए गए उदाहरण में देख सकते हैं।

<div class = "list">
   <label class = "item item-input">
      <input type = "text" placeholder = "Placeholder 1" />
   </label>

   <label class = "item item-input">
      <input type = "text" placeholder = "Placeholder 2" />
   </label>
</div>

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

आयोनिक लेबल

आयनिक आपके लेबल के लिए कुछ अन्य विकल्प प्रदान करता है। आप उपयोग कर सकते हैंinput-label वर्ग, यदि आप चाहते हैं कि पाठ लिखते समय आपका प्लेसहोल्डर बाईं ओर हो।

<div class = "list">
   <label class = "item item-input">
      <input type = "text" placeholder = "Placeholder 1" />
   </label>

   <label class = "item item-input">
      <input type = "text" placeholder = "Placeholder 2" />
   </label>
</div>

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

स्टैक्ड लेबल

Stacked labelएक अन्य विकल्प है जो आपके लेबल को इनपुट के ऊपर या नीचे ले जाने की अनुमति देता है। इसे प्राप्त करने के लिए, हम इसे जोड़ेंगेitem-stacked-label हमारे लेबल तत्व के लिए वर्ग और हमें एक नया तत्व बनाने और असाइन करने की आवश्यकता है input-labelइसके लिए कक्षा। यदि हम चाहते हैं कि यह शीर्ष पर रहे, तो हमें बस इस तत्व को जोड़ने की आवश्यकता हैinputटैग। यह निम्नलिखित उदाहरण में दिखाया गया है।

गौर करें कि द span टैग से पहले है inputटैग। यदि हमने उनके स्थान बदले, तो यह स्क्रीन पर नीचे दिखाई देगा।

<div class = "list">
   <label class = "item item-input item-stacked-label">
      <span class = "input-label">Label 1</span>
      <input type = "text" placeholder = "Placeholder 1" />
   </label>

   <label class = "item item-input item-stacked-label">
      <span class = "input-label">Label 2</span>
      <input type = "text" placeholder = "Placeholder 2" />
   </label>
</div>

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

फ्लोटिंग लेबल

Floating labelsतीसरा विकल्प है जिसका हम उपयोग कर सकते हैं। टाइप करना शुरू करने से पहले ये लेबल छिपा दिए जाएंगे। जैसे ही टाइपिंग शुरू होती है, वे अच्छे फ्लोटिंग एनीमेशन वाले तत्व के ऊपर दिखाई देंगे। हम फ्लोटिंग लेबल का उसी तरह उपयोग कर सकते हैं जैसे हमने स्टैक्ड लेबल का उपयोग किया था। अंतर केवल इतना है कि इस बार हम उपयोग करेंगेitem-floating-label कक्षा।

<div class = "list">
   <label class = "item item-input item-floating-label">
      <span class = "input-label"t>Label 1</span>
      <input type = "text" placeholder = "Placeholder 1" />
   </label>

   <label class = "item item-input item-floating-label">
      <span class = "input-label">Label 2</span>
      <input type = "text" placeholder = "Placeholder 2" />
   </label>
</div>

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

इनसेट इनपुट्स

अपने आखिरी अध्याय में, हमने चर्चा की कि आयोनिक तत्वों को कैसे सम्मिलित किया जाए। आप किसी इनपुट को इंसेट करके भी जोड़ सकते हैंitem-input-inset अपने आइटम और वर्ग के लिए item-input-wrapperअपने लेबल पर। एक आवरण आपके लेबल में अतिरिक्त स्टाइल जोड़ देगा।

यदि आप अपने लेबल के आगे कुछ अन्य तत्व जोड़ते हैं, तो लेबल का आकार नए तत्व को समायोजित करेगा। आप अपने लेबल (आमतौर पर आइकन) के अंदर भी तत्व जोड़ सकते हैं।

निम्न उदाहरण दो इनसेट इनपुट दिखाता है। पहले एक में लेबल के बगल में एक बटन है, और दूसरे में एक आइकन है। हमने इस्तेमाल कियाplaceholder-iconप्लेसहोल्डर टेक्स्ट के समान रंग के साथ आइकन बनाने के लिए क्लास। इसके बिना, आइकन लेबल के रंग का उपयोग करेगा।

<div class = "list">
   <div class = "item item-input-inset">
      <label class = "item item-input-wrapper">		
         <input type = "text" placeholder = "Placeholder 1" />
      </label>
      <button class = "button">button</button>
   </div>

   <div class = "item item-input-inset">
      <label class = "item item-input-wrapper">
         <i class = "icon ion-edit placeholder-icon"></i>
         <input type = "text" placeholder = "Placeholder 2" />
      </label>
   </div>
</div>

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

कभी-कभी उपयोगकर्ताओं के लिए दो विकल्प उपलब्ध होते हैं। इस स्थिति को संभालने का सबसे कुशल तरीका टॉगल रूपों के माध्यम से है। आयोनिक हमें टॉगल करने वाले तत्वों के लिए कक्षाएं देता है जो एनिमेटेड और लागू करने में आसान हैं।

टॉगल का उपयोग करना

टॉगल को दो आयनिक वर्गों का उपयोग करके लागू किया जा सकता है। सबसे पहले, हमें एक बनाने की जरूरत हैlabel उसी कारण के लिए हमने पिछले अध्याय में समझाया था और एक असाइन किया था toggle इसके लिए कक्षा।

हमारे अंदर लेबल बनाया जाएगा । आप निम्न उदाहरण में उपयोग किए जाने वाले दो और आयनिक वर्गों को देखेंगे। trackटॉगल टैप किए जाने पर क्लास हमारे चेकबॉक्स और कलर एनीमेशन में बैकग्राउंड स्टाइलिंग जोड़ देगा। handle वर्ग का उपयोग इसके लिए एक वृत्त बटन जोड़ने के लिए किया जाता है।

निम्नलिखित उदाहरण दो टॉगल रूपों को दर्शाता है। पहले एक की जाँच की जाती है, दूसरी नहीं।

<label class = "toggle">
   <input type = "checkbox" />
   <div class = "track">
      <div class = "handle"></div>
   </div>
</label>

<br>

<label class = "toggle">
   <input type = "checkbox" />
   <div class = "track">
      <div class = "handle"></div>
   </div>
</label>

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

मल्टीपल टॉगल

अधिकांश समय जब आप आयोनिक में एक ही तरह के एक से अधिक तत्वों को जोड़ना चाहते हैं, तो सबसे अच्छा तरीका सूची आइटम का उपयोग करना है। एकाधिक टॉगल के लिए उपयोग किया जाने वाला वर्ग हैitem-toggle। अगला उदाहरण दिखाता है कि टॉगल के लिए एक सूची कैसे बनाई जाए। पहले एक और दूसरे को चेक किया जाता है।

<ul class = "list">
   <li class = "item item-toggle">
      Toggle 1
      <label class = "toggle">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle 2
      <label class = "toggle">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle 3
      <label class = "toggle">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle 4
      <label class = "toggle">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>
</ul>

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

स्टाइलिंग टॉगल

सभी ईओण रंग वर्गों को टॉगल तत्व पर लागू किया जा सकता है। उपसर्ग होगाtoggle। हम इसे लागू करेंगेlabelतत्व। निम्नलिखित उदाहरण उन सभी रंगों को दिखाता है जो लागू होते हैं।

<ul class = "list">
   <li class = "item item-toggle">
      Toggle Light
      <label class = "toggle  toggle-light">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Stable
      <label class = "toggle toggle-stable">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Positive
      <label class = "toggle toggle-positive">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Calm
      <label class = "toggle toggle-calm">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Balanced
      <label class = "toggle toggle-balanced">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Energized
      <label class = "toggle toggle-energized">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Assertive
      <label class = "toggle toggle-assertive">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Royal
      <label class = "toggle  toggle-royal">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>

   <li class = "item item-toggle">
      Toggle Dark
      <label class = "toggle toggle-dark">
         <input type = "checkbox" />
         <div class = "track">
            <div class = "handle"></div>
         </div>
      </label>
   </li>
</ul>

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

Ionic checkboxलगभग टॉगल के समान है। इन दोनों को अलग-अलग ढंग से स्टाइल किया गया है लेकिन समान उद्देश्यों के लिए उपयोग किया जाता है।

चेकबॉक्स जोड़ना

चेकबॉक्स फ़ॉर्म बनाते समय, आपको जोड़ना होगा checkboxलेबल और इनपुट तत्वों दोनों का वर्ग नाम। निम्न उदाहरण दो सरल चेकबॉक्स दिखाता है, एक को चेक किया गया है और दूसरा नहीं है।

<label class = "checkbox">
   <input type = "checkbox">
</label>

<label class = "checkbox">
   <input type = "checkbox">
</label>

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

एकाधिक चेकबॉक्स

जैसा कि हमने पहले ही दिखाया, सूची का उपयोग कई तत्वों के लिए किया जाएगा। अब हम इसका उपयोग करेंगेitem-checkbox प्रत्येक सूची आइटम के लिए वर्ग।

<ul class = "list">
   <li class = "item item-checkbox">
      Checkbox 1
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox">
      Checkbox 2
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox">
      Checkbox e
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox">
      Checkbox 4
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>
</ul>

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

स्टाइलिंग चेकबॉक्स

जब आप एक चेकबॉक्स शैली करना चाहते हैं, तो आपको किसी भी आयोनिक रंग वर्ग के साथ आवेदन करना होगा checkboxउपसर्ग। निम्न उदाहरण देखें कि यह कैसा दिखता है। हम इस उदाहरण के लिए चेकबॉक्स की सूची का उपयोग करेंगे।

<ul class = "list">
   <li class = "item item-checkbox checkbox-light">
      Checkbox 1
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox checkbox-stable">
      Checkbox 2
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-positive">
      Checkbox 3
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-calm">
      Checkbox 4
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-balanced">
      Checkbox 5
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-energized">
      Checkbox 6
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-assertive">
      Checkbox 7
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-royal">
      Checkbox 8
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>

   <li class = "item item-checkbox  checkbox-dark">
      Checkbox 9
      <label class = "checkbox">
         <input type = "checkbox" />
      </label>
   </li>
</ul>

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

Radio buttonsएक तत्व का दूसरा रूप है, जिसे हम इस अध्याय में शामिल करेंगे। टॉगल और चेकबॉक्स रूपों से रेडियो बटन के बीच का अंतर यह है कि पूर्व का उपयोग करते समय, आप सूची से केवल एक रेडियो बटन चुनते हैं। जैसा कि उत्तरार्द्ध आपको एक से अधिक चुनने की अनुमति देता है।

रेडियो बटन जोड़ना

चूंकि चुनने के लिए हमेशा एक से अधिक रेडियो बटन होंगे, इसलिए सूची बनाने का सबसे अच्छा तरीका है। जब भी हम कई तत्व चाहते थे, हमने ऐसा किया। सूची आइटम वर्ग होगाitem-radio। फिर, हम उपयोग करेंगेlabelइसके लिए जैसा कि हमने अन्य सभी रूपों के साथ उपयोग किया है। इनपुट होगाnameविशेषता। यह विशेषता उन सभी बटनों को समूहित करेगी जिन्हें आप संभावित विकल्प के रूप में उपयोग करना चाहते हैं। item-contentक्लास का उपयोग विकल्पों को स्पष्ट रूप से प्रदर्शित करने के लिए किया जाता है। अंत में, हम उपयोग करेंगेradio-icon उपयोगकर्ता द्वारा चुने गए विकल्प को चिह्नित करने के लिए उपयोग किए जाने वाले चेकमार्क आइकन को जोड़ने के लिए वर्ग।

निम्नलिखित उदाहरण में, चार रेडियो बटन हैं और दूसरे को चुना गया है।

<div class = "list">
   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 1
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 2
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 3
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 4
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>
</div>

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

एकाधिक रेडियो बटन समूह

कभी-कभी आप एक से अधिक समूह बनाना चाहते हैं। यह क्या हैnameविशेषता के लिए बनाया गया है; निम्नलिखित उदाहरण पहले दो और अंतिम दो बटन को दो विकल्प समूहों के रूप में समूहित करेगा।

हम उपयोग करेंगे item-dividerदो समूहों को अलग करने के लिए कक्षा। ध्यान दें कि पहले समूह में हैname के बराबर विशेषता group1 और दूसरा उपयोग करता है group2

<div class = "list">
   <div class = " item item-divider">
      Group1
   </div>

   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 1
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <label class = "item item-radio">
      <input type = "radio" name = "group1" />
      <div class = "item-content">
         Choice 2
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <div class = "item item-divider">
      Group2
   </div>

   <label class = "item item-radio">
      <input type = "radio" name = "group2" />
      <div class = "item-content">
         Choice 3
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>

   <label class = "item item-radio">
      <input type = "radio" name = "group2" />
      <div class = "item-content">
         Choice 4
      </div>
      <i class = "radio-icon ion-checkmark"></i>
   </label>
</div>

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

Ionic रेंज का उपयोग किसी चीज के स्तर को चुनने और प्रदर्शित करने के लिए किया जाता है। यह अधिकतम और न्यूनतम मूल्य के सह-संबंध में वास्तविक मूल्य का प्रतिनिधित्व करेगा। आयोनिक रेंज के साथ काम करने का एक सरल तरीका प्रदान करता है।

रेंज का उपयोग करना

रेंज का उपयोग अंदर के तत्व तत्व के रूप में किया जाता है। उपयोग किया जाने वाला वर्ग हैrange। हम इस वर्ग को इसके बाद स्थान देंगेitemकक्षा। यह एक कंटेनर तैयार करेगा जहां सीमा रखी जाएगी। एक कंटेनर बनाने के बाद, हमें जोड़ना होगाinput और असाइन करें range इसे टाइप करें और name विशेषता भी।

<div class = "item range">
   <input type = "range" name = "range1">
</div>

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

प्रतीक जोड़ना

रेंज आमतौर पर डेटा को स्पष्ट रूप से प्रदर्शित करने के लिए आइकन की आवश्यकता होगी। हमें रेंज इनपुट के पहले और बाद में उन्हें रेंज एलिमेंट के दोनों ओर लगाने के लिए आइकन जोड़ना होगा।

<div class = "item range">
   <i class = "icon ion-volume-low"></i>
   <input type = "range" name = "volume">
   <i class = "icon ion-volume-high"></i>
</div>

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

स्टाइलिंग रेंज

हमारा अगला उदाहरण आपको दिखाएगा कि आयोनिक रंगों के साथ रेंज को कैसे स्टाइल किया जाए। रंग वर्गों एक का उपयोग करेगाrangeउपसर्ग। हम नौ श्रेणियों के साथ एक सूची बनाएंगे और इसे अलग तरह से स्टाइल करेंगे।

<div class = "list">
   <div class = "item range range-light">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-stable">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-positive">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-calm">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-balanced">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-energized">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-assertive">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-royal">
      <input type = "range" name = "volume">
   </div>
	
   <div class = "item range range-dark">
      <input type = "range" name = "volume">
   </div>
</div>

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

Ionic Selectउपयोगकर्ता को चुनने के लिए चुनिंदा विकल्पों के साथ एक सरल मेनू बनाएगा। यह चयन मेनू अलग-अलग प्लेटफार्मों पर अलग-अलग दिखाई देगा, क्योंकि इसकी स्टाइल ब्राउज़र द्वारा नियंत्रित की जाती है।

चयन का उपयोग करना

सबसे पहले, हम एक बनाएँगे label और जोड़ें item-input और यह item-selectकक्षाएं। दूसरा वर्ग चुनिंदा फॉर्म में अतिरिक्त स्टाइल जोड़ देगा और फिर हम जोड़ देंगेinput-labelहमारे अंदर का वर्ग हमारे चयनित तत्व में नाम जोड़ने के लिए उपयोग किया जाएगा। हम भी जोड़ देंगेselect साथ में optionके भीतर। यह नियमित HTML5 चुनिंदा तत्व है। निम्नलिखित उदाहरण तीन विकल्पों के साथ आयनिक चयन दिखा रहा है।

<label class = "item item-input item-select">
   <div class = "input-label">
      Select
   </div>
	
   <select>
      <option>Option 1</option>
      <option selected>Option 2</option>
      <option>Option 3</option>
   </select>
</label>

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

स्टाइल का चयन करें

निम्नलिखित उदाहरण आपको दिखाएंगे कि चयन करने के लिए स्टाइल कैसे लागू करें। हम नौ अलग-अलग स्टाइल वाले चुनिंदा तत्वों के साथ एक सूची बना रहे हैं जो आयोनिक रंगों का उपयोग कर रहे हैं। चूंकि हम आइटम के साथ सूची का उपयोग कर रहे हैं,item रंग वर्गों के लिए उपसर्ग होगा।

<div class = "list">
   <label class = "item item-input item-select item-light">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-stable">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-positive">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-calm">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-balanced">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-energized">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-assertive">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-royal">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>

   <label class = "item item-input item-select item-dark">
      <div class = "input-label">
         Select
      </div>
		
      <select>
         <option>Option 1</option>
         <option selected>Option 2</option>
         <option>Option 3</option>
      </select>
   </label>
</div>

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

Ionic tabsअधिकांश समय मोबाइल नेविगेशन के लिए उपयोग किए जाते हैं। स्टाइलिंग को विभिन्न प्लेटफार्मों के लिए अनुकूलित किया गया है। इसका मतलब है कि एंड्रॉइड डिवाइस पर, टैब को स्क्रीन के शीर्ष पर रखा जाएगा, जबकि IOS पर यह सबसे नीचे होगा। टैब बनाने के विभिन्न तरीके हैं। हम इस अध्याय में टैब बनाने के तरीके के बारे में विस्तार से समझेंगे।

साधारण टैब्स

सरल टैब मेनू के साथ बनाया जा सकता है tabsकक्षा। इस वर्ग का उपयोग करने वाले अंदर के तत्व के लिए, हमें जोड़ने की आवश्यकता हैtab-itemतत्वों। चूंकि टैब आमतौर पर नेविगेशन के लिए उपयोग किया जाता है, हम उपयोग करेंगे<a>टैब आइटम के लिए टैग। निम्न उदाहरण चार टैब के साथ एक मेनू दिखा रहा है।

<div class = "tabs">
   <a class = "tab-item">
      Tab 1
   </a>
	
   <a class = "tab-item">
      Tab 2
   </a>

   <a class = "tab-item">
      Tab 3
   </a>
</div>

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

प्रतीक जोड़ना

Ionic टैब में आइकन जोड़ने के लिए कक्षाएं प्रदान करता है। यदि आप चाहते हैं कि आपके टैब में बिना किसी टेक्स्ट के आइकन हों, तोtabs-icon-only के बाद वर्ग जोड़ा जाना चाहिए tabsकक्षा। बेशक, आपको उन आइकन को जोड़ना होगा जिन्हें आप प्रदर्शित करना चाहते हैं।

<div class = "tabs tabs-icon-only">
   <a class = "tab-item">
      <i class = "icon ion-home"></i>
   </a>
	
   <a class = "tab-item">
      <i class = "icon ion-star"></i>
   </a>
	
   <a class = "tab-item">
      <i class = "icon ion-planet"></i>
   </a>
</div>

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

आप एक साथ आइकन और टेक्स्ट भी जोड़ सकते हैं। tabs-icon-top तथा tabs-icon-leftऐसी कक्षाएं हैं जो क्रमशः ऊपर या बाईं ओर आइकन को रखेंगी। कार्यान्वयन ऊपर दिए गए उदाहरण के समान है, हम बस एक नया वर्ग और पाठ जोड़ देंगे जिसका हम उपयोग करना चाहते हैं। निम्न उदाहरण पाठ के ऊपर रखे गए आइकन दिखाता है।

<div class = "tabs tabs-icon-top">
   <a class = "tab-item">
      <i class = "icon ion-home"></i>
      Tab 1
   </a>
	
   <a class = "tab-item">
      <i class = "icon ion-star"></i>
      Tab 2
   </a>
	
   <a class = "tab-item">
      <i class = "icon ion-planet"></i>
      Tab 3
   </a>
</div>

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

धारीदार टैब

धारीदार टैब हमारे टैब के साथ एक कंटेनर को जोड़कर बनाया जा सकता है tabs-stripedकक्षा। इस वर्ग के उपयोग की अनुमति देता हैtabs-background और यह tabs-color टैब मेनू में कुछ आयोनिक रंगों को जोड़ने के लिए उपसर्ग।

निम्नलिखित उदाहरण में, हम इसका उपयोग करेंगे tabs-background-positive (नीले) वर्ग हमारे मेनू की पृष्ठभूमि शैली के लिए, और tabs-color-light(सफेद) टैब आइकनों को स्टाइल करने के लिए क्लास। दूसरे टैब के बीच का अंतर देखें जो सक्रिय है और अन्य दो जो नहीं हैं।

<div class = "tabs-striped tabs-background-positive tabs-color-light">
   <div class = "tabs">
      <a class = "tab-item">
         <i class = "icon ion-home"></i>
      </a>
		
      <a class = "tab-item active">
         <i class = "icon ion-star"></i>
      </a>
		
      <a class = "tab-item">
         <i class = "icon ion-planet"></i>
      </a>
   </div>
</div>

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

के साथ काम कर रहा है Ionic Grid Systemसीधा है। दो मुख्य वर्ग हैं -row पंक्तियों के साथ काम करने के लिए और col स्तंभों के लिए।

आप जितनी चाहें उतने कॉलम या पंक्तियाँ चुन सकते हैं। वे सभी उपलब्ध स्थान को समायोजित करने के लिए इसके आकार को समायोजित करेंगे, हालांकि आप अपनी आवश्यकताओं के अनुरूप इस व्यवहार को बदल सकते हैं।

NOTE - इस ट्यूटोरियल के सभी उदाहरणों में हमारे ग्रिड पर लागू होने वाली सीमाएँ होंगी, जो इसे इस तरह से प्रदर्शित करने में सक्षम होंगी, जिन्हें समझना आसान है।

सिंपल ग्रिड

निम्न उदाहरण दिखाता है कि कैसे उपयोग किया जाए col और यह rowकक्षाएं। हम दो पंक्तियों का निर्माण करेंगे। पहली पंक्ति में पाँच कॉलम होंगे और दूसरी पंक्ति में केवल तीन होंगे। ध्यान दें कि पहली और दूसरी पंक्ति में स्तंभों की चौड़ाई अलग-अलग कैसे होती है।

<div class = "row">
   <div class = "col">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
   <div class = "col">col 4</div>
   <div class = "col">col 5</div>
</div>

<div class = "row">
   <div class = "col">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
</div>

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

कॉलम आकार

कभी-कभी आप स्वचालित रूप से असाइन किए गए स्तंभ आकारों को छोड़ना नहीं चाहते हैं। यदि यह मामला है, तो आप चुन सकते हैंcol एक संख्या के बाद उपसर्ग जो एक प्रतिशत का प्रतिनिधित्व करेगा rowचौड़ाई। यह केवल एक विशिष्ट आकार वाले कॉलम पर लागू होगा। अन्य कॉलम बचे हुए उपलब्ध स्थान पर समायोजित हो जाएंगे।

निम्नलिखित उदाहरण में, पहला कॉलम पूरी चौड़ाई का 50 प्रतिशत उपयोग करेगा और अन्य तदनुसार समायोजित करेगा।

<div class = "row">
   <div class = "col col-50">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
   <div class = "col">col 4</div>
   <div class = "col">col 5</div>
</div>

<div class = "row">
   <div class = "col col-50">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
</div>

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

निम्न तालिका आयोनिक ग्रिड प्रणाली प्रदान करता है कि उपलब्ध प्रतिशत विकल्प दिखाता है -

कॉलम प्रतिशत वर्ग के नाम

कक्षा का नाम प्रतिशत उपयोग किया जाता है
col-10 10%
कॉल-20 20%
कॉल-25 25%
col-33 33.3333%
col-50 50%
col-67 66.6666%
col-75 75%
col-80 80%
col-90 90%

क्षैतिज और ऊर्ध्वाधर स्थिति

कॉलम बाईं ओर से ऑफसेट किया जा सकता है। यह स्तंभों के विशिष्ट आकार के लिए समान कार्य करता है। इस बार उपसर्ग होगाcol-offsetऔर फिर हम ऊपर तालिका में दिखाए गए समान प्रतिशत संख्याओं का उपयोग करेंगे। निम्नलिखित उदाहरण से पता चलता है कि हम दोनों पंक्तियों के दूसरे कॉलम को 25 प्रतिशत तक कैसे ऑफसेट कर सकते हैं।

<div class = "row">
   <div class = "col">col 1</div>
   <div class = "col col-offset-25">col 2</div>
   <div class = "col">col 3</div>
   <div class = "col">col 4</div>
   <div class = "col">col 5</div>
</div>

<div class = "row">
   <div class = "col">col 1</div>
   <div class = "col col-offset-25">col 2</div>
   <div class = "col">col 3</div>
</div>

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

आप पंक्ति के अंदर स्तंभों को लंबवत रूप से संरेखित कर सकते हैं। तीन वर्ग हैं, जिनका उपयोग किया जा सकता है, अर्थात् -top, center और यह bottom के साथ वर्ग colउपसर्ग। निम्न कोड दिखाता है कि दोनों पंक्तियों के पहले तीन स्तंभों को लंबवत कैसे रखा जाए

NOTE - उदाहरण में जो हमने जोड़ा है “.col {height: 120px}” स्तंभों के ऊर्ध्वाधर रखने के लिए हमारे सीएसएस को देखें।

<div class = "row">
   <div class = "col col-top">col 1</div>
   <div class = "col col-center">col 2</div>
   <div class = "col col-bottom">col 3</div>
   <div class = "col">col 4</div>
   <div class = "col">col 5</div>
</div>

<div class = "row">
   <div class = "col col-top">col 1</div>
   <div class = "col col-center">col 2</div>
   <div class = "col col-bottom">col 3</div>
</div>

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

उत्तरदायी ग्रिड

आयनिक ग्रिड का उपयोग एक उत्तरदायी लेआउट के लिए भी किया जा सकता है। तीन कक्षाएं उपलब्ध हैं। responsive-smजब दृश्य लैंडस्केप फोन से छोटा होता है तो क्लास एक ही पंक्ति में कॉलम को ध्वस्त कर देगी। responsive-mdजब व्यूपोर्ट किसी पोर्ट्रेट टैबलेट से छोटा होगा तब क्लास लगाया जाएगा। responsive-lg जब व्यूपोर्ट एक लैंडस्केप टैबलेट से छोटा होगा तब क्लास लगाया जाएगा।

निम्नलिखित उदाहरण के बाद पहली छवि दिखाती है कि कैसे responsive-sm क्लास एक मोबाइल डिवाइस पर दिखता है और दूसरा दिखाता है कि टैब्लेट डिवाइस पर समान रूप से उत्तरदायी ग्रिड कैसे दिखता है।

<div class = "row responsive-sm">
   <div class = "col col-25">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
   <div class = "col">col 4</div>
   <div class = "col">col 5</div>
</div>

<div class = "row responsive-sm">
   <div class = "col">col 1</div>
   <div class = "col">col 2</div>
   <div class = "col">col 3</div>
</div>

मोबाइल ग्रिड देखें

टेबलेट ग्रिड देखें

इससे ज़्यादा हैं 700 premium iconsIonic द्वारा प्रदान किया गया। एंड्रॉइड और IOS के लिए प्रदान किए गए आइकन के विभिन्न सेट भी हैं। आप अपनी आवश्यकता के अनुसार लगभग कुछ भी पा सकते हैं, लेकिन यदि आप नहीं चाहते हैं, तो आप उनका उपयोग करने के लिए बाध्य नहीं हैं। आप अपने स्वयं के कस्टम आइकन या इसके बजाय किसी अन्य आइकन सेट का उपयोग कर सकते हैं। आप सभी Ionic आइकन यहां देख सकते हैं ।

कैसे करें आइकॉन का इस्तेमाल?

यदि आप Ionic आइकन का उपयोग करना चाहते हैं तो पृष्ठ पर आपको जो आइकन चाहिए वह ढूंढें (https://ionicons.com/)। जब आप ईओण तत्वों को जोड़ रहे हैं, तो आप हमेशा मुख्य वर्ग को पहले जोड़ते हैं और फिर आप अपने इच्छित उपवर्ग को जोड़ते हैं। सभी आइकन के लिए मुख्य वर्ग हैicon। उपवर्ग आपके इच्छित आइकन का नाम है। हम अपने उदाहरण में छह चिह्न जोड़ेंगे जो नीचे दिए गए हैं -

<i class = "icon icon ion-happy-outline"></i>
<i class = "icon icon ion-star"></i>
<i class = "icon icon ion-compass"></i>
<i class = "icon icon ion-planet"></i>
<i class = "icon icon ion-ios-analytics"></i>
<i class = "icon icon ion-ios-eye"></i>

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

इन आइकन के आकार को इसके साथ बदला जा सकता है font-size आयोनिक सीएसएस फ़ाइल में संपत्ति।

.icon {
   font-size: 50px;
}

एक बार आइकन का आकार सेटअप होने के बाद, समान कोड आउटपुट के रूप में निम्न स्क्रीनशॉट का उत्पादन करेगा -

डिफ़ॉल्ट प्रतीक

कोड परिणाम
<i class = "आइकन आयन-आयनिक"> </ i>
<i class = "आइकन आयन-एरो-अप-ए"> </ i>
<i class = "आइकन आयन-एरो-राइट-ए"> </ i>
<i class = "आइकन आयन-एरो-डाउन-ए"> </ i>
<i class = "आइकन आयन-एरो-लेफ्ट-ए"> </ i>
<i class = "आइकन आयन-एरो-अप-बी"> </ i>
<i class = "आइकन आयन-एरो-राइट-बी"> </ i>
<i class = "आइकन आयन-तीर-डाउन-बी"> </ i>
<i class = "आइकन आयन-एरो-लेफ्ट-बी"> </ i>
<i class = "आइकन आयन-एरो-अप-सी"> </ i>
<i class = "आइकन आयन-एरो-राइट-सी"> </ i>
<i class = "आइकन आयन-तीर-डाउन-सी"> </ i>
<i class = "आइकन आयन-तीर-बाएं-सी"> </ i>
<i class = "आइकन आयन-एरो-रिटर्न-राइट"> </ i>
<i class = "आइकन आयन-तीर-वापसी-बाएं"> </ i>
<i class = "आइकन आयन-तीर-स्वैप"> </ i>
<i class = "आइकन आयन-तीर-सिकुड़न"> </ i>
<i class = "आइकन आयन-तीर-विस्तार"> </ i>
<i class = "आइकन आयन-तीर-चाल"> </ i>
<i class = "आइकन आयन-तीर-आकार बदलें"> </ i>
<i class = "आइकन आयन-शेवरॉन-अप"> </ i>
<i class = "आइकन आयन-शेवरॉन-राइट"> </ i>
<i class = "आइकन आयन-शेवरॉन-डाउन"> </ i>
<i class = "icon ion-chevron-left"> </ i>
<i class = "icon ion-navicon-round"> ​​</ i>
<i class = "icon ion-navicon"> </ i>
<i class = "आइकन आयन-ड्रैग"> </ i>
<i class = "आइकन आयन-लॉग-इन"> </ i>
<i class = "आइकन आयन-लॉग-आउट"> </ i>
<i class = "आइकन आयन-चेकमार्क-राउंड"> </ i>
<i class = "आइकन आयन-चेकमार्क"> </ i>
<i class = "आइकन आयन-चेकमार्क-परिचालित"> </ i>
<i class = "आइकन आयन-क्लोज़-राउंड"> </ i>
<i class = "icon ion-close"> </ i>
<i class = "आइकन आयन-पास-चक्कर"> </ i>
<i class = "आइकन आयन-प्लस-राउंड"> </ i>
<i class = "आइकन आयन-प्लस"> </ i>
<i class = "आइकन आयन-प्लस-सर्किल"> </ i>
<i class = "आइकन आयन-माइनस-राउंड"> </ i>
<i class = "आइकन आयन-माइनस"> </ i>
<i class = "आइकन आयन-माइनस-सर्किल"> </ i>
<i class = "आइकन आयन-सूचना"> </ i>
<i class = "आइकन आयन-सूचनात्मक आयन-चक्कर"> </ i>
<i class = "आइकन आयन-सहायता"> </ i>
<i class = "icon ion-help-circled"> </ i>
<i class = "आइकन आयन-बैकस्पेस-आउटलाइन"> </ i>
<i class = "आइकन आयन-बैकस्पेस"> </ i>
<i class = "आइकन आयन-सहायता-बोय"> </ i>
<i class = "आइकन आयन-तारांकन"> </ i>
<i class = "आइकन आयन-अलर्ट"> </ i>
<i class = "आइकन आयन-अलर्ट-सर्किल"> </ i>
<i class = "आइकन आयन-ताज़ा"> </ i>
<i class = "आइकन आयन-लूप"> </ i>
<i class = "आइकन आयन-शफल"> </ i>
<i class = "आइकन आयन-होम"> </ i>
<i class = "आइकन आयन-खोज"> </ i>
<i class = "आइकन आयन-ध्वज"> </ i>
<i class = "आइकन आयन-स्टार"> </ i>
<i class = "आइकन आयन-हृदय"> </ i>
<i class = "आइकन आयन-दिल-टूटा"> </ i>
<i class = "आइकन आयन-गियर-ए"> </ i>
<i class = "आइकन आयन-गियर-बी"> </ i>
<i class = "आइकन आयन-टॉगल-भरा"> </ i>
<i class = "आइकन आयन-टॉगल"> </ i>
<i class = "आइकन आयन सेटिंग्स"> </ i>
<i class = "आइकन आयन-रिंच"> </ i>
<i class = "आइकन आयन-हथौड़ा"> </ i>
<i class = "आइकन आयन-संपादन"> </ i>
<i class = "आइकन आयन-कचरा-एक"> </ i>
<i class = "आइकन आयन-कचरा-बी"> </ i>
<i class = "आइकन आयन-दस्तावेज़"> </ i>
<i class = "आइकन आयन-दस्तावेज़-पाठ"> </ i>
<i class = "आइकन आयन-क्लिपबोर्ड"> </ i>
<i class = "आइकन आयन-कैंची"> </ i>
<i class = "आइकन आयन-फ़नल"> </ i>
<i class = "आइकन आयन-बुकमार्क"> </ i>
<i class = "आइकन आयन-ईमेल"> </ i>
<i class = "आइकन आयन-ईमेल-अपठित"> </ i>
<i class = "आइकन आयन-फ़ोल्डर"> </ i>
<i class = "आइकन आयन-फाइलिंग"> </ i>
<i class = "आइकन आयन-संग्रह"> </ i>
<i class = "आइकन आयन-उत्तर"> </ i>
<i class = "आइकन आयन-उत्तर-सभी"> </ i>
<i class = "आइकन आयन-फ़ॉरवर्ड"> </ i>
<i class = "आइकन आयन-शेयर"> </ i>
<i class = "आइकन आयन-पेपर-हवाई जहाज"> </ i>
<i class = "आइकन आयन-लिंक"> </ i>
<i class = "आइकन आयन-पेपरक्लिप"> </ i>
<i class = "आइकन आयन-रचना"> </ i>
<i class = "आइकन आयन-अटैची"> </ i>
<i class = "आइकन आयन-मेडिटक"> </ i>
<i class = "icon ion-at"> </ i>
<i class = "आइकन आयन-पाउंड"> </ i>
<i class = "आइकन आयन-उद्धरण"> </ i>
<i class = "आइकन आयन-क्लाउड"> </ i>
<i class = "आइकन आयन-अपलोड"> </ i>
<i class = "आइकन आयन-अधिक"> </ i>
<i class = "आइकन आयन-ग्रिड"> </ i>
<i class = "आइकन आयन-कैलेंडर"> </ i>
<i class = "आइकन आयन-घड़ी"> </ i>
<i class = "आइकन आयन-कम्पास"> </ i>
<i class = "आइकन आयन-पिनपॉइंट"> </ i>
<i class = "आइकन आयन-पिन"> </ i>
<i class = "आइकन आयन-नेविगेट"> </ i>
<i class = "आइकन आयन-स्थान"> </ i>
<i class = "आइकन आयन-मैप"> </ i>
<i class = "आइकन आयन-लॉक-संयोजन"> </ i>
<i class = "आइकन आयन-लॉक"> </ i>
<i class = "आइकन आयन-अनलॉक"> </ i>
<i class = "आइकन आयन-कुंजी"> </ i>
<i class = "आइकन आयन-एरो-ग्राफ-अप-राइट"> </ i>
<i class = "आइकन आयन-एरो-ग्राफ-डाउन-राइट"> </ i>
<i class = "आइकन आयन-एरो-ग्राफ-अप-लेफ्ट"> </ i>
<i class = "आइकन आयन-एरो-ग्राफ-डाउन-लेफ्ट"> </ i>
<i class = "आइकन आयन-सांख्यिकी-बार"> </ i>
<i class = "आइकन आयन-कनेक्टिकॉन आयन-बार"> </ i>
<i class = "आइकन आयन-पाई-ग्राफ"> </ i>
<i class = "आइकन आयन-चैटबेल"> </ i>
<i class = "icon ion-chatbubble-working"> </ i>
<i class = "आइकन आयन-चैटबबल्स"> </ i>
<i class = "आइकन आयन-चैटबॉक्स"> </ i>
<i class = "आइकन आयन-चैटबॉक्स-वर्किंग"> </ i>
<i class = "आइकन आयन-चैटबॉक्स"> </ i>
<i class = "आइकन आयन-व्यक्ति"> </ i>
<i class = "icon ion-person-add"> </ i>
<i class = "icon ion-person-stalker"> </ i>
<i class = "आइकन आयन-महिला"> </ i>
<i class = "आइकन आयन-मैन"> </ i>
<i class = "आइकन आयन-महिला"> </ i>
<i class = "आइकन आयन-पुरुष"> </ i>
<i class = "आइकन आयन-ट्रांसजेंडर"> </ i>
<i class = "आइकन आयन-कांटा"> </ i>
<i class = "आइकन आयन-चाकू"> </ i>
<i class = "आइकन आयन-स्पून"> </ i>
<i class = "आइकन आयन-सूप-कैन-आउटलाइन"> </ i>
<i class = "आइकन आयन-सूप-कैन"> </ i>
<i class = "आइकन आयन-बीयर"> </ i>
<i class = "आइकन आयन-वाइन ग्लास"> </ i>
<i class = "आइकन आयन-कॉफी"> </ i>
<i class = "आइकन आयन-आइक्रीम"> </ i>
<i class = "आइकन आयन-पिज्जा"> </ i>
<i class = "आइकन आयन-पावर"> </ i>
<i class = "आइकन आयन-माउस"> </ i>
<i class = "आइकन आयन-बैटरी-पूर्ण"> </ i>
<i class = "आइकन आयन-बैटरी-आधा"> </ i>
<i class = "आइकन आयन-बैटरी-कम"> </ i>
<i class = "आइकन आयन-बैटरी-खाली"> </ i>
<i class = "आइकन आयन-बैटरी-चार्जिंग"> </ i>
<i class = "आइकन आयन-वाईफाई"> </ i>
<i class = "आइकन आयन-ब्लूटूथ"> </ i>
<i class = "आइकन आयन-कैलकुलेटर"> </ i>
<i class = "आइकन आयन-कैमरा"> </ i>
<i class = "आइकन आयन-आई"> </ i>
<i class = "आइकन आयन-आई-अक्षम"> </ i>
<i class = "आइकन आयन-फ्लैश"> </ i>
<i class = "आइकन आयन-फ्लैश-ऑफ"> </ i>
<i class = "आइकन आयन-qr- स्कैनर"> </ i>
<i class = "आइकन आयन-छवि"> </ i>
<i class = "आइकन आयन-चित्र"> </ i>
<i class = "आइकन आयन-वैंड"> </ i>
<i class = "आइकन आयन-कंट्रास्ट"> </ i>
<i class = "आइकन आयन-एपर्चर"> </ i>
<i class = "आइकन आयन-फसल"> </ i>
<i class = "icon ion-easel"> </ i>
<i class = "आइकन आयन-पेंटब्रश"> </ i>
<i class = "आइकन आयन-पेंटबकेट"> </ i>
<i class = "आइकन आयन-मॉनिटर"> </ i>
<i class = "आइकन आयन-लैपटॉप"> </ i>
<i class = "आइकन आयन-आईपैड"> </ i>
<i class = "आइकन आयन-आईफ़ोन"> </ i>
<i class = "आइकन आयन-आईपॉड"> </ i>
<i class = "आइकन आयन-प्रिंटर"> </ i>
<i class = "आइकन आयन-यूएसबी"> </ i>
<i class = "आइकन आयन-आउटलेट"> </ i>
<i class = "आइकन आयन-बग"> </ i>
<i class = "आइकन आयन-कोड"> </ i>
<i class = "icon ion-code-working"> </ i>
<i class = "आइकन आयन-कोड-डाउनलोड"> </ i>
<i class = "आइकन आयन-फोर्क-रेपो"> </ i>
<i class = "आइकन आयन-नेटवर्क"> </ i>
<i class = "आइकन आयन-पुल-अनुरोध"> </ i>
<i class = "आइकन आयन-मर्ज"> </ i>
<i class = "आइकन आयन-एक्सबॉक्स"> </ i>
<i class = "आइकन आयन-प्लेस्टेशन"> </ i>
<i class = "आइकन आयन-स्टीम"> </ i>
<i class = "आइकन आयन-बंद-कैप्शनिंग"> </ i>
<i class = "icon ion-videocamera"> </ i>
<i class = "आइकन आयन-फिल्म-मार्कर"> </ i>
<i class = "आइकन आयन-डिस्क"> </ i>
<i class = "आइकन आयन-हेडफ़ोन"> </ i>
<i class = "आइकन आयन-संगीत-नोट"> </ i>
<i class = "आइकन आयन-रेडियो-वेव्स"> </ i>
<i class = "आइकन आयन-स्पीकरफ़ोन"> </ i>
<i class = "आइकन आयन-माइक-ए"> </ i>
<i class = "आइकन आयन-माइक-बी"> </ i>
<i class = "आइकन आयन-माइक-सी"> </ i>
<i class = "आइकन आयन-वॉल्यूम-उच्च"> </ i>
<i class = "आइकन आयन-वॉल्यूम-माध्यम"> </ i>
<i class = "आइकन आयन-वॉल्यूम-कम"> </ i>
<i class = "आइकन आयन-वॉल्यूम-म्यूट"> </ i>
<i class = "आइकन आयन-स्तर"> </ i>
<i class = "आइकन आयन-प्ले"> </ i>
<i class = "आइकन आयन-पॉज़"> </ i>
<i class = "आइकन आयन-स्टॉप"> </ i>
<i class = "आइकन आयन-रिकॉर्ड"> </ i>
<i class = "आइकन आयन-स्किप-फॉरवर्ड"> </ i>
<i class = "आइकन आयन-स्किप-बैकवर्ड"> </ i>
<i class = "आइकन आयन-इजेक्ट"> </ i>
<i class = "आइकन आयन-बैग"> </ i>
<i class = "आइकन आयन-कार्ड"> </ i>
<i class = "आइकन आयन-कैश"> </ i>
<i class = "icon ion-pricetag"> </ i>
<i class = "icon ion-pricetags"> </ i>
<i class = "आइकन आयन-थम्सअप"> </ i>
<i class = "आइकन आयन-थम्बस्डाउन"> </ i>
<i class = "icon ion-happy-outline"> </ i>
<i class = "आइकन आयन-खुश"> </ i>
<i class = "icon ion-sad-outline"> </ i>
<i class = "आइकन आयन-उदास"> </ i>
<i class = "आइकन आयन-बॉल"> </ i>
<i class = "आइकन आयन-टीशर्ट-रूपरेखा"> </ i>
<i class = "आइकन आयन-टीशर्ट"> </ i>
<i class = "आइकन आयन-ट्रॉफी"> </ i>
<i class = "आइकन आयन-पोडियम"> </ i>
<i class = "आइकन आयन-रिबन-एक"> </ i>
<i class = "आइकन आयन-रिबन-बी"> </ i>
<i class = "आइकन आयन-विश्वविद्यालय"> </ i>
<i class = "आइकन आयन-चुंबक"> </ i>
<i class = "आइकन आयन-बीकर"> </ i>
<i class = "आइकन आयन-इरलेनमेयर-फ्लास्क"> </ i>
<i class = "आइकन आयन-अंडा"> </ i>
<i class = "आइकन आयन-अर्थ"> </ i>
<i class = "आइकन आयन-ग्रह"> </ i>
<i class = "आइकन आयन-लाइटबल्ब"> </ i>
<i class = "आइकन आयन-घन"> </ i>
<i class = "आइकन आयन-पत्ती"> </ i>
<i class = "आइकन आयन-वाटरड्रॉप"> </ i>
<i class = "आइकन आयन-लौ"> </ i>
<i class = "आइकन आयन-फायरबॉल"> </ i>
<i class = "आइकन आयन-अलाव"> </ i>
<i class = "आइकन आयन-छाता"> </ i>
<i class = "आइकन आयन-परमाणु"> </ i>
<i class = "आइकन आयन-नो-स्मोकिंग"> </ i>
<i class = "आइकन आयन-थर्मामीटर"> </ i>
<i class = "आइकन आयन-स्पीडोमीटर"> </ i>
<i class = "आइकन आयन-मॉडल-एस"> </ i>
<i class = "आइकन आयन-प्लेन"> </ i>
<i class = "आइकन आयन-जेट"> </ i>
<i class = "आइकन आयन-लोड-ए"> </ i>
<i class = "आइकन आयन-लोड-बी"> </ i>
<i class = "आइकन आयन-लोड-सी"> </ i>
<i class = "आइकन आयन-लोड-डी"> </ i>

आईओएस स्टाइल आइकॉन

कोड परिणाम
<i class = "आइकन आयन-आयन-आयनिक-रूपरेखा"> </ i>
<i class = "आइकन आयन-आयोस-तीर-बैक"> </ i>
<i class = "आइकन आयन-आयोस-तीर-आगे"> </ i>
<i class = "आइकन आयन-आयोस-तीर-अप"> </ i>
<i class = "आइकन आयन-आयोस-एरो-राइट"> </ i>
<i class = "आइकन आयन-आयोस-एरो-डाउन"> </ i>
<i class = "icon ion-ios-arrow-left"> </ i>
<i class = "आइकन आयन-आयोस-तीर-पतला-अप"> </ i>
<i class = "आइकन आयन-आयोस-तीर-थिन-राइट"> </ i>
<i class = "आइकन आयन-आयोस-तीर-थिन-डाउन"> </ i>
<i class = "आइकन आयन-आयोस-एरो-थिन-लेफ्ट"> </ i>
<i class = "आइकन आयन-आयोस-सर्कल-भरा"> </ i>
<i class = "आइकन आयन-आयोस-सर्कल-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-चेकमार्क-खाली"> </ i>
<i class = "आइकन आयन-आईओएस-चेकमार्क-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-चेकमार्क"> </ i>
<i class = "आइकन आयन-आईओएस-प्लस-खाली"> </ i>
<i class = "आइकन आयन-आईओएस-प्लस-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-प्लस"> </ i>
<i class = "आइकन आयन-आईओएस-क्लोज-खाली"> </ i>
<i class = "icon ion-ios-close-outline"> </ i>
<i class = "आइकन आयन-आईओएस-क्लोज़"> </ i>
<i class = "आइकन आयन-आईओएस-माइनस-खाली"> </ i>
<i class = "आइकन आयन-आईओएस-माइनस-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-माइनस"> </ i>
<i class = "आइकन आयन-आईओएस-इनफॉर्मेटिकन आयन-खाली"> </ i>
<i class = "आइकन आयन-आईओएस-इनफॉर्मेटिकॉन आयन-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-सूचना"> </ i>
<i class = "आइकन आयन-आईओएस-सहायता-रिक्त"> </ i>
<i class = "आइकन आयन-आईओएस-सहायता-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-सहायता"> </ i>
<i class = "आइकन आयन-आईओएस-खोज"> </ i>
<i class = "icon ion-ios-search-strong"> </ i>
<i class = "आइकन आयन-आईओएस-स्टार"> </ i>
<i class = "आइकन आयन-आईओएस-स्टार-हाफ"> </ i>
<i class = "आइकन आयन-आईओएस-स्टार-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-हार्ट"> </ i>
<i class = "आइकन आयन-आईओएस-हार्ट-आउटलाइन"> </ i>
<i class = "आइकन आयन-आयोस-अधिक"> </ i>
<i class = "आइकन आयन-आईओएस-अधिक-रूपरेखा"> </ i>
<i class = "icon आयन-होम"> </ i>
<i class = "आइकन आयन-आईओएस-होम-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-अपलोड"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-अपलोड-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-डाउनलोड"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-डाउनलोड-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-अपलोड"> </ i>
<i class = "icon ion-ios-upload-outline"> </ i>
<i class = "आइकन आयन-आईओएस-डाउनलोड"> </ i>
<i class = "आइकन आयन-आईओएस-डाउनलोड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रिफ्रेश"> </ i>
<i class = "आइकन आयन-आईओएस-रिफ्रेश-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रिफ्रेश-खाली"> </ i>
<i class = "icon ion-ios-reload"> </ i>
<i class = "आइकन आयन-आईओएस-लूप-मजबूत"> </ i>
<i class = "आइकन आयन-आईओएस-लूप"> </ i>
<i class = "आइकन आयन-आईओएस-बुकमार्क"> </ i>
<i class = "आइकन आयन-आईओएस-बुकमार्क्स-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-बुक"> </ i>
<i class = "icon ion-ios-book-outline"> </ i>
<i class = "आइकन आयन-आईओएस-ध्वज"> </ i>
<i class = "आइकन आयन-आईओएस-ध्वज-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-चश्मा"> </ i>
<i class = "आइकन आयन-आईओएस-चश्मा-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-ब्राउज़र"> </ i>
<i class = "आइकन आयन-आईओएस-ब्राउज़र-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-ऑन"> </ i>
<i class = "icon ion-ios-at-outline"> </ i>
<i class = "आइकन आयन-आयोस-प्रिसेटैग"> </ i>
<i class = "आइकन आयन-आईओएस-प्रिसेटैग-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-प्रिसेटैग्स"> </ i>
<i class = "आइकन आयन-आईओएस-प्रिसेटैग-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-कार्ट"> </ i>
<i class = "आइकन आयन-आईओएस-कार्ट-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-चैटबॉक्स"> </ i>
<i class = "आइकन आयन-आईओएस-चैटबॉक्स-आउटलाइन"> </ i>
<i class = "icon ion-ios-chatbubble"> </ i>
<i class = "आइकन आयन-आईओएस-चैटबेल-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-कॉग"> </ i>
<i class = "आइकन आयन-आईओएस-कॉग-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-गियर"> </ i>
<i class = "आइकन आयन-आईओएस-गियर-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-सेटिंग"> </ i>
<i class = "आइकन आयन-आईओएस-सेटिंग्स-मजबूत"> </ i>
<i class = "आइकन आयन-आईओएस-टॉगल"> </ i>
<i class = "आइकन आयन-आईओएस-टॉगल-रूपरेखा"> </ i>
<i class = "icon ion-ios-analytics"> </ i>
<i class = "icon ion-ios-analytics-outline"> </ i>
<i class = "आइकन आयन-आयोस-पाई"> </ i>
<i class = "आइकन आयन-आयोस-पाई-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-पल्स"> </ i>
<i class = "आइकन आयन-आईओएस-पल्स-मजबूत"> </ i>
<i class = "आइकन आयन-आईओएस-फाइलिंग"> </ i>
<i class = "आइकन आयन-आयोस-फाइलिंग-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-बॉक्स"> </ i>
<i class = "आइकन आयन-आईओएस-बॉक्स-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रचना"> </ i>
<i class = "आइकन आयन-आईओएस-रचना-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-कचरा"> </ i>
<i class = "आइकन आयन-आयोस-कचरा-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-कॉपी"> </ i>
<i class = "icon ion-ios-copy-outline"> </ i>
<i class = "आइकन आयन-आईओएस-ईमेल"> </ i>
<i class = "आइकन आयन-आईओएस-ईमेल-रूपरेखा"> </ i>
<i class = "icon ion-ios-undo"> </ i>
<i class = "आइकन आयन-आईओएस-पूर्ववत रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-रीडो"> </ i>
<i class = "आइकन आयन-आयोस-रीडो-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-पेपरप्लेन"> </ i>
<i class = "आइकन आयन-आयोस-पेपरप्लेन-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-फ़ोल्डर"> </ i>
<i class = "आइकन आयन-आईओएस-फ़ोल्डर-रूपरेखा"> </ i>
<i class = "आइकन आयन-आयोस-पेपर"> </ i>
<i class = "आइकन आयन-आयोस-पेपर-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-सूची"> </ i>
<i class = "आइकन आयन-आईओएस-सूची-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-दुनिया"> </ i>
<i class = "icon ion-ios-world-outline"> </ i>
<i class = "आइकन आयन-आईओएस-अलार्म"> </ i>
<i class = "आइकन आयन-आईओएस-अलार्म-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-स्पीडोमीटर"> </ i>
<i class = "आइकन आयन-आईओएस-स्पीडोमीटर-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-स्टॉपवॉच"> </ i>
<i class = "आइकन आयन-आईओएस-स्टॉपवॉच-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-टाइमर"> </ i>
<i class = "आइकन आयन-आईओएस-टाइमर-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-घड़ी"> </ i>
<i class = "आइकन आयन-आईओएस-घड़ी-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-टाइम"> </ i>
<i class = "आइकन आयन-आईओएस-टाइम-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-कैलेंडर"> </ i>
<i class = "आइकन आयन-आईओएस-कैलेंडर-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-फोटो"> </ i>
<i class = "icon ion-ios-photos-outline"> </ i>
<i class = "आइकन आयन-आईओएस-एल्बम"> </ i>
<i class = "आइकन आयन-आईओएस-एल्बम-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-कैमरा"> </ i>
<i class = "आइकन आयन-आईओएस-कैमरा-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-रिवर्स-कैमरा"> </ i>
<i class = "आइकन आयन-आईओएस-रिवर्स-कैमरा-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-आई"> </ i>
<i class = "आइकन आयन-आईओएस-आई-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-बोल्ट"> </ i>
<i class = "आइकन आयन-आईओएस-बोल्ट-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रंग-छड़ी"> </ i>
<i class = "आइकन आयन-आईओएस-कलर-वैंड-आउटलाइन"> </ i>
<i class = "icon आयन-रंग-फ़िल्टर"> </ i>
<i class = "icon आयन-रंग-फ़िल्टर-रूपरेखा"> </ i>
<i class = "आइकन आयन-आयोस-ग्रिड-व्यू"> </ i>
<i class = "आइकन आयन-आयोस-ग्रिड-व्यू-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-फसल-मजबूत"> </ i>
<i class = "आइकन आयन-आईओएस-फसल"> </ i>
<i class = "आइकन आयन-आयोस-बारकोड"> </ i>
<i class = "आइकन आयन-आयोस-बारकोड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-ब्रीफ़केस"> </ i>
<i class = "आइकन आयन-आईओएस-अटैची-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-मेडिटक"> </ i>
<i class = "icon आयन-मेड-मेडकिट-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-मेडिकल"> </ i>
<i class = "आइकन आयन-आईओएस-चिकित्सा-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-अनंत"> </ i>
<i class = "आइकन आयन-आईओएस-अनंत-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-कैलकुलेटर"> </ i>
<i class = "आइकन आयन-आईओएस-कैलकुलेटर-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-कीपैड"> </ i>
<i class = "आइकन आयन-आईओएस-कीपैड-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-टेलीफोन"> </ i>
<i class = "आइकन आयन-आईओएस-टेलीफोन-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-ड्रैग"> </ i>
<i class = "आइकन आयन-आईओएस-लोकेशन"> </ i>
<i class = "आइकन आयन-आईओएस-लोकेटिकॉन आयन-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-नेविगेट"> </ i>
<i class = "आइकन आयन-आईओएस-नेविगेट-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-लॉक"> </ i>
<i class = "आइकन आयन-आईओएस-लॉक-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-अनलॉक"> </ i>
<i class = "आइकन आयन-आईओएस-अनलॉक-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-मॉनिटर"> </ i>
<i class = "आइकन आयन-आईओएस-मॉनिटर-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-प्रिंटर"> </ i>
<i class = "आइकन आयन-आईओएस-प्रिंटर-रूपरेखा"> </ i>
<i class = "icon आयन-गेम-कंट्रोलर-अ"> </ i>
<i class = "icon आयन-गेम-कंट्रोलर-ए-आउटलाइन"> </ i>
<i class = "आइकन आयन-आयोस-गेम-कंट्रोलर-बी"> </ i>
<i class = "आइकन आयन-आईओएस-गेम-कंट्रोलर-बी-आउटलाइन"> </ i>
<i class = "आइकॉन आयन-आईओएस- americanfootball"> </ i>
<i class = "आइकॉन आयन-आईओएस- americanfootball-outline"> </ i>
<i class = "आइकन आयन-आईओएस-बेसबॉल"> </ i>
<i class = "आइकन आयन-आईओएस-बेसबॉल-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-बास्केटबॉल"> </ i>
<i class = "आइकन आयन-आईओएस-बास्केटबॉल-रूपरेखा"> </ i और gtgt;
<i class = "आइकन आयन-आईओएस-टेनिसबॉल"> </ i>
<i class = "आइकन आयन-आईओएस-टेनिसबॉल-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-फुटबॉल"> </ i>
<i class = "आइकन आयन-आईओएस-फुटबॉल-रूपरेखा"> </ i>
<i class = "आइकन आयन-आयोस-बॉडी"> </ i>
<i class = "आइकन आयन-आयोस-बॉडी-आउटलाइन"> </ i>
<i class = "आइकन आयन-आयोस-व्यक्ति"> </ i>
<i class = "आइकन आयन-आयोस-व्यक्ति-रूपरेखा"> </ i>
<i class = "icon ion-ios-personadd"> </ i>
<i class = "आइकन आयन-आईओएस-व्यक्तिवाद-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-लोग"> </ i>
<i class = "आइकन आयन-आईओएस-लोग-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-संगीत-नोट्स"> </ i>
<i class = "icon ion-ios-musical-note"> </ i>
<i class = "आइकन आयन-आईओएस-घंटी"> </ i>
<i class = "आइकन आयन-आईओएस-बेल-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-माइक"> </ i>
<i class = "आइकन आयन-आईओएस-माइक-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-माइक-ऑफ"> </ i>
<i class = "आइकन आयन-आयोस-वॉल्यूम-उच्च"> </ i>
<i class = "आइकन आयन-आयोस-वॉल्यूम-कम"> </ i>
<i class = "आइकन आयन-आईओएस-प्ले"> </ i>
<i class = "आइकन आयन-आईओएस-प्ले-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-पॉज़"> </ i>
<i class = "आइकन आयन-आईओएस-पॉज़-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रिकॉर्डिंग"> </ i>
<i class = "आइकन आयन-आईओएस-रिकॉर्डिंग-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-फास्टफोर्वर्ड"> </ i>
<i class = "आइकन आयन-आईओएस-फास्टफोर्वर्ड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-रिवाइंड"> </ i>
<i class = "आइकन आयन-आयोस-रिवाइंड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-स्किपबैकवर्ड"> </ i>
<i class = "आइकन आयन-आईओएस-स्किपबैकवर्ड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-स्किपवर्डवर्ड"> </ i>
<i class = "आइकन आयन-आईओएस-स्किपवर्डवर्ड-आउटलाइन"> </ i>
<i class = "icon ion-ios-shuffle-strong"> </ i>
<i class = "icon ion-ios-shuffle"> </ i>
<i class = "आइकन आयन-आईओएस-वीडियोकैम"> </ i>
<i class = "icon ion-ios-videocam-outline"> </ i>
<i class = "आइकन आयन-आईओएस-फिल्म"> </ i>
<i class = "आइकन आयन-आईओएस-फिल्म-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-फ्लास्क"> </ i>
<i class = "आइकन आयन-आईओएस-फ्लास्क-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-लाइटबल्ब"> </ i>
<i class = "आइकन आयन-आईओएस-लाइटबल्ब-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-वाइन ग्लास"> </ i>
<i class = "आइकन आयन-आईओएस-वाइनग्लास-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-पिंट"> </ i>
<i class = "icon ion-ios-pint-outline"> </ i>
<i class = "आइकन आयन-आईओएस-पोषण"> </ i>
<i class = "आइकन आयन-आईओएस-न्यूट्रिशनिक आयन-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-फूल"> </ i>
<i class = "आइकन आयन-आईओएस-फूल-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-गुलाब"> </ i>
<i class = "आइकन आयन-आईओएस-गुलाब-रूपरेखा"> </ i>
<i class = "आइकन आयन-आईओएस-पंजा"> </ i>
<i class = "icon ion-ios-paw-outline"> </ i>
<i class = "आइकन आयन-आयोस-फ्लेम"> </ i>
<i class = "आइकन आयन-आयोस-फ्लेम-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-सनी"> </ i>
<i class = "आइकन आयन-आईओएस-सनी-रूपरेखा"> </ i>
<i class = "आइकॉन आयन-आईओएस-पार्टलिंसनी"> </ i>
<i class = "icon ion-ios-partlysunny-outline"> </ i>
<i class = "आइकन आयन-आईओएस-बादल"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-बरसात"> </ i>
<i class = "icon ion-ios-rainy-outline"> </ i>
<i class = "आइकन आयन-आईओएस-थंडरस्टॉर्म"> </ i>
<i class = "आइकन आयन-आईओएस-थंडरस्टॉर्म-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-बर्फी"> </ i>
<i class = "आइकन आयन-आईओएस-चंद्रमा"> </ i>
<i class = "आइकन आयन-आयोस-मून-आउटलाइन"> </ i>
<i class = "आइकन आयन-आईओएस-बादल-रात"> </ i>
<i class = "आइकन आयन-आईओएस-क्लाउड-नाइट-आउटलाइन"> </ i>

Android स्टाइल आइकन

कोड परिणाम
<i class = "आइकन आयन-एंड्रॉइड-एरो-अप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-फ़ॉरवर्ड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-डाउन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-बैक"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपअप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपअप-सर्कल"> </ i>
<i class = "icon ion-android-arrow-dropright"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपराइट-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपडाउन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपडाउन-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपप्लेट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एरो-ड्रॉपप्लेट-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ऐड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ऐड-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रिमूव"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रिम-सर्कल"> </ i>
<i class = "icon ion-android-close"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रद्द करें"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रेडियो-बटन-ऑफ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रेडियो-बटन-ऑन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेकमार्क-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेकबॉक्स-आउटलाइन-रिक्त"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेकबॉक्स-आउटलाइन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेकबॉक्स-रिक्त"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेकबॉक्स"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-किया"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-किया-सभी"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-मेनू"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अधिक-क्षैतिज"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अधिक-ऊर्ध्वाधर"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रिफ्रेश"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सिंक"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वाईफाई"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कॉल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ऐप्स"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सेटिंग्स"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-विकल्प"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फ़नल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-खोज"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-होम"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-क्लाउड-आउटलाइन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-क्लाउड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-डाउनलोड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अपलोड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-क्लाउड-किया गया"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-क्लाउड-सर्कल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-पसंदीदा-रूपरेखा"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-पसंदीदा"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-स्टार-आउटलाइन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-स्टार-हाफ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-स्टार"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कैलेंडर"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अलार्म-घड़ी"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-टाइम"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-स्टॉपवॉच"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉच"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-पता"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-नेविगेट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-पिन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कंपास"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-मैप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉक"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-साइकिल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कार"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-बस"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सबवे"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ट्रेन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-बोट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-प्लेन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रेस्तरां"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-बार"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कार्ट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कैमरा"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-इमेज"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फिल्म"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-रंग-पैलेट"> </ i>
<i class = "icon ion-android-create"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-मेल"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ड्राफ्ट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-भेजें"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-आर्काइव"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-डिलीट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अटैचमेंट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-शेयर"> </ i>
<i class = "icon ion-android-share-alt"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-बुकमार्क"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-डॉक्यूमेंट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-क्लिपबोर्ड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-लिस्ट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फ़ोल्डर-ओपन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फ़ोल्डर"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-प्रिंट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ओपन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-एग्जिट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-कॉन्ट्रैक्ट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-विस्तार"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ग्लोब"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चैट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-ग्रंथ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-हैंगआउट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-खुश"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सैड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-व्यक्ति"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-लोग"> </ i>
<i class = "icon ion-android-person-add"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-संपर्क"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-संपर्क"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-प्लेस्टोर"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-लॉक"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अनलॉक"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-माइक्रोफ़ोन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-माइक्रोफोन-ऑफ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सूचनाएं-कोई नहीं"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-नोटिफिकेशन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-नोटिफिकेशन-ऑफ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉल्यूम-म्यूट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉल्यूम-डाउन"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉल्यूम-अप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-वॉल्यूम-ऑफ"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-हैंड"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-डेस्कटॉप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-लैपटॉप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फोन-पोर्ट्रेट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-फोन-लैंडस्केप"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-बल्ब"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-सनी"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-अलर्ट"> </ i>
<i class = "आइकन आयन-एंड्रॉइड-चेतावनी"> </ i>

सामाजिक प्रतीक

कोड परिणाम
<i class = "आइकन आयन-सोशल-ट्विटर"> </ i>
<i class = "आइकन आयन-सोशल-ट्विटर-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-फेसबुक"> </ i>
<i class = "आइकन आयन-सामाजिक-फेसबुक-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-Googleplus"> </ i>
<i class = "icon ion-social-googleplus-outline"> </ i>
<i class = "icon ion-social-google"> </ i>
<i class = "icon ion-social-google-outline"> </ i>
<i class = "आइकन आयन-सामाजिक-ड्रिबल"> </ i>
<i class = "आइकन आयन-सामाजिक-ड्रिबल-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-ऑक्टोकैट"> </ i>
<i class = "आइकन आयन-सामाजिक-जीथब"> </ i>
<i class = "आइकन आयन-सोशल-गिथब-आउटलाइन"> </ i>
<i class = "आइकन आयन-सोशल-इंस्टाग्राम"> </ i>
<i class = "आइकन आयन-सोशल-इंस्टाग्राम-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-व्हाट्सएप"> </ i>
<i class = "आइकन आयन-सामाजिक-व्हाट्सएप-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-स्नैपचैट"> </ i>
<i class = "आइकन आयन-सामाजिक-स्नैपचैट-रूपरेखा"> </ i>
<i class = "आइकन आयन-सोशल-फोरस्क्वेयर"> </ i>
<i class = "आइकन आयन-सोशल-फोरस्क्वेयर-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-Pinterest"> </ i>
<i class = "आइकन आयन-सोशल-पिनटेरेस्ट-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-आरएसएस"> </ i>
<i class = "आइकन आयन-सामाजिक-आरएसएस-रूपरेखा"> </ i>
<i class = "आइकन आयन-सोशल-टंबलर"> </ i>
<i class = "आइकन आयन-सामाजिक-टंबलर-रूपरेखा"> </ i>
<i class = "आइकन आयन-सोशल-वर्डप्रेस"> </ i>
<i class = "आइकन आयन-सोशल-वर्डप्रेस-आउटलाइन"> </ i>
<i class = "आइकन आयन-सोशल-रेडिट"> </ i>
<i class = "आइकन आयन-सोशल-रेडिट-आउटलाइन"> </ i>
<i class = "icon ion-social-hackernews"> </ i>
<i class = "icon ion-social-hackernews-outline"> </ i>
<i class = "icon ion-social-designernews"> </ i>
<i class = "आइकन आयन-सामाजिक-डिज़ाइनरन्यूज़-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-याहू"> </ i>
<i class = "आइकन आयन-सामाजिक-याहू-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-बफर"> </ i>
<i class = "आइकन आयन-सामाजिक-बफर-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-स्काइप"> </ i>
<i class = "आइकन आयन-सामाजिक-स्काइप-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-लिंक्डइन"> </ i>
<i class = "आइकन आयन-सामाजिक-लिंक्डइन-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-विमो"> </ i>
<i class = "आइकन आयन-सामाजिक-विमो-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-चिकोटी"> </ i>
<i class = "आइकन आयन-सामाजिक-चिकोटी-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-यूट्यूब"> </ i>
<i class = "icon ion-social-youtube-outline"> </ i>
<i class = "आइकन आयन-सामाजिक-ड्रॉपबॉक्स"> </ i>
<i class = "आइकन आयन-सामाजिक-ड्रॉपबॉक्स-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-सेब"> </ i>
<i class = "आइकन आयन-सामाजिक-सेब-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-एंड्रॉइड"> </ i>
<i class = "आइकन आयन-सोशल-एंड्रॉइड-आउटलाइन"> </ i>
<i class = "आइकन आयन-सामाजिक-विंडोज़"> </ i>
<i class = "आइकन आयन-सामाजिक-विंडोज़-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-एचटीएमएल 5"> </ i>
<i class = "आइकन आयन-सामाजिक-एचटीएमएल 5-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-सीएसएस 3"> </ i>
<i class = "आइकन आयन-सामाजिक-सीएसएस 3-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-जावास्क्रिप्ट"> </ i>
<i class = "आइकन आयन-सामाजिक-जावास्क्रिप्ट-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-कोणीय"> </ i>
<i class = "आइकन आयन-सामाजिक-कोणीय-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-नोडज"> </ i>
<i class = "icon ion-social-sass"> </ i>
<i class = "आइकन आयन-सामाजिक-पायथन"> </ i>
<i class = "आइकन आयन-सामाजिक-क्रोम"> </ i>
<i class = "आइकन आयन-सामाजिक-क्रोम-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-कोडपेन"> </ i>
<i class = "आइकन आयन-सामाजिक-कोडपेन-रूपरेखा"> </ i>
<i class = "आइकन आयन-सोशल-मार्कडाउन"> </ i>
<i class = "आइकन आयन-सोशल-टक्स"> </ i>
<i class = "आइकन आयन-सामाजिक-मुक्त-शैतान"> </ i>
<i class = "आइकन आयन-सोशल-यूएसडी"> </ i>
<i class = "आइकन आयन-सामाजिक-यूएसडी-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-बिटकॉइन"> </ i>
<i class = "आइकन आयन-सामाजिक-बिटकॉइन-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-येन"> </ i>
<i class = "आइकन आयन-सामाजिक-येन-रूपरेखा"> </ i>
<i class = "आइकन आयन-सामाजिक-यूरो"> </ i>
<i class = "आइकन आयन-सामाजिक-यूरो-रूपरेखा"> </ i>

आयनिक तत्वों में पैडिंग जोड़ने का एक आसान तरीका प्रदान करता है। ऐसी कुछ कक्षाएं हैं जिनका उपयोग किया जा सकता है और उनमें से सभी को जोड़ा जाएगा10pxतत्व और उसकी सामग्री की सीमा के बीच। निम्न तालिका सभी उपलब्ध गद्दी वर्गों को प्रदर्शित करती है।

पैडिंग क्लासेस

कक्षा का नाम कक्षा की जानकारी
गद्दी हर तरफ पैडिंग लगाता है।
गद्दी-ऊर्ध्वाधर ऊपर और नीचे तक पैडिंग जोड़ता है।
गद्दी-क्षैतिज बाईं और दाईं ओर पैडिंग जोड़ता है।
पैडिंग शीर्ष शीर्ष पर पैडिंग जोड़ता है।
गद्दी-सही पैडिंग को दाईं ओर जोड़ता है।
नीचे गद्दी करना पैडिंग को नीचे तक जोड़ता है।
गद्दी छूट गई बाईं ओर पैडिंग जोड़ता है।

पैडिंग का उपयोग करना

जब आप अपने तत्व के लिए कुछ पैडिंग लागू करना चाहते हैं, तो आपको ऊपर दी गई तालिका में से किसी एक कक्षा को असाइन करना होगा। निम्न उदाहरण दो ब्लॉक बटन दिखाता है। पहले एक का उपयोग कर रहा हैpaddingवर्ग और दूसरा नहीं है। आप देखेंगे कि पहला बटन बड़ा है, क्योंकि यह है10px गद्दी लगा दी।

<div class = "button button-block padding">Padding</div>
<div class = "button button-block">No padding</div>

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

Action Sheet एक आयनिक सेवा है जो स्क्रीन के नीचे एक स्लाइड अप फलक को ट्रिगर करेगी, जिसे आप विभिन्न उद्देश्यों के लिए उपयोग कर सकते हैं।

एक्शन शीट का उपयोग करना

निम्नलिखित उदाहरण में, हम आपको दिखाएंगे कि Ionic एक्शन शीट का उपयोग कैसे करें। पहले हम इंजेक्ट करेंगे$ionicActionSheet हमारे नियंत्रक के लिए एक निर्भरता के रूप में सेवा, फिर हम बनाएंगे $scope.showActionSheet() फ़ंक्शन, और अंतिम रूप से हम अपने HTML टेम्पलेट में एक बटन बनाएंगे जो हमारे द्वारा बनाए गए फ़ंक्शन को कॉल करेगा।

नियंत्रक कोड

.controller('myCtrl', function($scope, $ionicActionSheet) {
   $scope.triggerActionSheet = function() { // Show the action sheet var showActionSheet = $ionicActionSheet.show({
         buttons: [
            { text: 'Edit 1' },
            { text: 'Edit 2' }
         ],
			
         destructiveText: 'Delete',
         titleText: 'Action Sheet',
         cancelText: 'Cancel',
			
         cancel: function() {
            // add cancel code...
         },
			
         buttonClicked: function(index) {
            if(index === 0) {
               // add edit 1 code
            }
				
            if(index === 1) {
               // add edit 2 code
            }
         },
			
         destructiveButtonClicked: function() {
            // add delete code..
         }
      });
   };
})

HTML कोड

<button class = "button">Action Sheet Button</button>

कोड समझाया गया

जब हम बटन पर टैप करेंगे, तो यह ट्रिगर हो जाएगा $ionicActionSheet.showफ़ंक्शन और एक्शन शीट दिखाई देगी। आप अपने स्वयं के फ़ंक्शंस बना सकते हैं जिन्हें तब बुलाया जाएगा जब कोई एक विकल्प टैप किया जाएगा। cancel फ़ंक्शन फलक को बंद कर देगा, लेकिन आप कुछ अन्य व्यवहार जोड़ सकते हैं, जिसे तब बुलाया जाएगा जब फलक बंद होने से पहले रद्द विकल्प टैप किया जाता है।

buttonClickedफ़ंक्शन वह स्थान है जहां आप उस कोड को लिख सकते हैं जिसे कॉल किया जाएगा जब संपादन विकल्पों में से एक टैप किया जाएगा। हम का उपयोग करके कई बटन का ट्रैक रख सकते हैंindexपैरामीटर। destructiveButtonCLickedएक ऐसा फ़ंक्शन है जिसे डिलीट विकल्प टैप करने पर ट्रिगर किया जाएगा। यह विकल्प हैred by default

$ionicActionSheet.show()विधि में कुछ अन्य उपयोगी पैरामीटर हैं। आप निम्नलिखित तालिका में उन सभी की जांच कर सकते हैं।

विधि विकल्प दिखाएँ

गुण प्रकार विवरण
बटन वस्तु एक टेक्स्ट फ़ील्ड के साथ बटन ऑब्जेक्ट बनाता है।
titleText तार एक्शन शीट का शीर्षक।
cancelText तार रद्द करें बटन के लिए पाठ।
destructiveText तार एक विनाशकारी बटन के लिए पाठ।
रद्द करना समारोह कैंसल बटन, बैकड्रॉप या हार्डवेयर बैक बटन दबाने पर कॉल किया जाता है।
buttonClicked समारोह बटन में से एक को टैप करने पर कॉल किया जाता है। इंडेक्स का इस्तेमाल किस बटन पर टैप करने के लिए किया जाता है। सही रिटर्न एक्शन शीट को बंद कर देगा।
destructiveButtonClicked समारोह विनाशकारी बटन पर क्लिक करने पर कॉल किया जाता है। सही रिटर्न एक्शन शीट को बंद कर देगा।
cancelOnStateChange बूलियन यदि सही (डिफ़ॉल्ट) यह नेविगेशन स्थिति बदलने पर एक्शन शीट को रद्द कर देगा।

Ionic Backdropलागू होने पर स्क्रीन की सामग्री को ओवरले करेंगे। यह अन्य ओवरले (पॉपअप, लोडिंग, आदि ...) के नीचे दिखाई देगा। ऐसी दो विधियाँ हैं जिनका उपयोग पृष्ठभूमि सेवा के प्रबंधन के लिए किया जा सकता है। $ionicBackdrop.retain() घटकों पर पृष्ठभूमि लागू होगा, और $ionicBackdrop.release() निकाल देंगे।

पृष्ठभूमि का उपयोग करना

निम्न उदाहरण दिखाता है कि पृष्ठभूमि का उपयोग कैसे करें। हम जोड़ रहे हैं$ionicBackdrop नियंत्रक के लिए एक निर्भरता के रूप में, फिर बनाने $scope.showBackdrop() फ़ंक्शन जो कॉल करेगा retain methodहाथोंहाथ। फिर, तीन सेकंड के बाद, यह कॉल करेगाrelease method। हम प्रयोग कर रहे हैं$timeout रिलीज़ विधि के लिए, इसलिए हमें इसे एक नियंत्रक निर्भरता के रूप में भी जोड़ने की आवश्यकता है।

.controller('myCtrl', function($scope, $ionicBackdrop, $timeout) {
   $scope.showBackdrop = function() { $ionicBackdrop.retain();
		
      $timeout(function() { $ionicBackdrop.release();
      }, 3000);
   };
})

आप ध्यान देंगे कि पृष्ठभूमि को लागू करने के बाद से स्क्रीन निम्न छवि में कैसे गहरा है।

लगभग हर मोबाइल ऐप में कुछ मूलभूत तत्व होते हैं। आमतौर पर इन तत्वों में एक हेडर और एक पाद शामिल होता है, जो स्क्रीन के ऊपर और नीचे के हिस्से को कवर करेगा। अन्य सभी तत्वों को इन दोनों के बीच रखा जाएगा। आयोनिक एक कंटेनर के रूप में कार्य करने वाले आयन-सामग्री तत्व प्रदान करता है, जो अन्य सभी तत्वों को लपेटेगा जो हम बनाना चाहते हैं।

आइए हम निम्नलिखित उदाहरण पर विचार करें -

<div class = "bar bar-header"> 
   <h1 class = "title">Header</h1> 
</div>

<div class = "list"> 
   <label class = "item item-input"> 
      <input type = "text" placeholder = "Placeholder 1" /> 
   </label>
   
   <label class = "item item-input"> 
      <input type = "text" placeholder = "Placeholder 2" /> 
   </label> 
</div>

<div class = "bar bar-footer"> 
   <h1 class = "title">Footer</h1> 
</div>

इस अध्याय में, हम समझेंगे कि जावास्क्रिप्ट फॉर्म क्या हैं और यह सीखेंगे कि जावास्क्रिप्ट चेकबॉक्स, रेडियो बटन और टॉगल क्या हैं।

आयन-चेकबॉक्स का उपयोग करना

आइए देखें कि Ionic जावास्क्रिप्ट चेकबॉक्स का उपयोग कैसे करें। सबसे पहले, हम एक बनाने की जरूरत हैion-checkboxHTML फ़ाइल में तत्व। इसके अंदर, हम एक असाइन करेंगेng-model विशेषता जो कोणीय से जुड़ी होगी $scope। आप देखेंगे कि हम एक का उपयोग कर रहे हैंdotएक मॉडल के मूल्य को परिभाषित करते हुए भले ही यह इसके बिना काम करेगा। यह हमें हर समय बच्चे और माता-पिता के बीच संबंध बनाए रखने की अनुमति देगा।

यह बहुत महत्वपूर्ण है क्योंकि यह भविष्य में होने वाले कुछ मुद्दों से बचने में मदद करता है। तत्व बनाने के बाद, हम कोणीय भावों का उपयोग करके इसके मान को बांधेंगे।

<ion-checkbox ng-model = "checkboxModel.value1">Checkbox 1</ion-checkbox>
<ion-checkbox ng-model = "checkboxModel.value2">Checkbox 2</ion-checkbox>

<p>Checkbox 1 value is: <b>{{checkboxModel.value1}}</b></p>
<p>Checkbox 2 value is: <b>{{checkboxModel.value2}}</b></p>

अगला, हमें नियंत्रक के अंदर अपने मॉडल को मान असाइन करने की आवश्यकता है। हम जिन मूल्यों का उपयोग करेंगे, वे हैंfalse, क्योंकि हम अनियंत्रित चेकबॉक्स से शुरू करना चाहते हैं।

$scope.checkboxModel = {
   value1 : false,
   value2 : false
};

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

अब, जब हम चेकबॉक्स तत्वों को टैप करते हैं, तो यह स्वतः ही उनके मॉडल मान को बदल देगा “true” जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

आयन-रेडियो का उपयोग करना

शुरू करने के लिए, हमें तीन बनाने चाहिए ion-radio हमारे HTML में तत्व और असाइन करें ng-model और यह ng-valueयह करने के लिए। उसके बाद, हम कोणीय अभिव्यक्ति के साथ चुने हुए मूल्य को प्रदर्शित करेंगे। हम सभी तीन रेडियोलेक्शंस को अनचेक करके शुरू करेंगे, इसलिए मूल्य हमारी स्क्रीन को नहीं सौंपा जाएगा।

<ion-radio ng-model = "radioModel.value" ng-value = "1">Radio 1</ion-radio>
<ion-radio ng-model = "radioModel.value" ng-value = "2">Radio 2</ion-radio>
<ion-radio ng-model = "radioModel.value" ng-value = "3">Radio 3</ion-radio>

<p>Radio value is: <b>{{radioModel.value}}</b></p>

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

जब हम दूसरे चेकबॉक्स तत्व पर टैप करते हैं, तो मान उसी के अनुसार बदल जाएगा।

आयन-टॉगल का उपयोग करना

आप देखेंगे कि टॉगल चेकबॉक्स के समान है। हम उन्हीं चरणों का पालन करेंगे जैसा हमने अपने चेकबॉक्स के साथ किया था। HTML फ़ाइल में, पहले हम बनाएंगेion-toggle तत्वों, तो असाइन करें ng-model मूल्य और फिर हमारे दृष्टिकोण के अभिव्यक्ति मूल्यों को बांधते हैं।

<ion-toggle ng-model = "toggleModel.value1">Toggle 1</ion-toggle>
<ion-toggle ng-model = "toggleModel.value2">Toggle 2</ion-toggle>
<ion-toggle ng-model = "toggleModel.value3">Toggle 3</ion-toggle>

<p>Toggle value 1 is: <b>{{toggleModel.value1}}</b></p>
<p>Toggle value 2 is: <b>{{toggleModel.value2}}</b></p>
<p>Toggle value 3 is: <b>{{toggleModel.value3}}</b></p>

अगला, हम मान निर्दिष्ट करेंगे $scope.toggleModelहमारे नियंत्रक में। चूंकि, टॉगल बूलियन मूल्यों का उपयोग करता है, हम असाइन करेंगेtrue पहले तत्व के लिए और false अन्य दो के लिए।

$scope.toggleModel = {
   value1 : true,
   value2 : false,
   value3 : false
};

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

अब हम दूसरे और तीसरे टॉगल पर टैप करके आपको दिखाएंगे कि वैल्यूज़ कैसे झूठ से सच में बदलती हैं।

उपयोगकर्ताओं के साथ सहभागिता जोड़ने के लिए विभिन्न आयोनिक घटनाओं का उपयोग किया जा सकता है। निम्न तालिका सभी आयोनिक घटनाओं की व्याख्या करती है।

कार्यक्रम नाम घटना का विवरण
होल्ड पर स्पर्श की अवधि 500ms से अधिक होने पर कॉल किया जाता है।
नल पर स्पर्श की अवधि 250ms से कम होने पर कॉल किया जाता है।
ऑन-दो बार टैप करें डबल टैप टच होने पर कॉल किया जाता है।
छूने पर स्पर्श शुरू होने पर तुरंत फोन किया।
रिहाई पर स्पर्श समाप्त होने पर बुलाया जाता है।
पर खींचें किसी भी दिशा में पृष्ठ के चारों ओर विमोचन किए बिना स्पर्श किए जाने पर कॉल किया जाता है।
पर खींचें-अप जब एलिमेंट को घसीटा जाता है तो कॉल किया जाता है।
ऑन-ड्रैग सही जब तत्व को दाईं ओर खींचा जाता है, तो कॉल किया जाता है।
ऑन-खींचें छोड़ दिया जब तत्व को बाईं ओर घसीटा जाता है, तब कॉल किया जाता है।
ऑन-ड्रैग नीचे जब तत्व को नीचे खींचा जाता है तो कॉल किया जाता है।
ऑन-कड़ी चोट जब किसी भी खींच को उच्च वेग से किसी भी दिशा में ले जाने पर कॉल किया जाता है।
ऑन-कड़ी चोट-अप जब किसी भी ड्रैगिंग में उच्च वेग बढ़ रहा हो, तब कॉल किया जाता है।
ऑन-स्वाइप-सही किसी भी ड्रैगिंग के दाईं ओर बढ़ने पर उच्च वेग होता है।
ऑन-स्वाइप-छोड़ दिया जब किसी भी खींचने को उच्च वेग से बाईं ओर ले जाने को कहा जाता है।
ऑन-कड़ी चोट से नीचे जब किसी भी खींच को उच्च वेग नीचे ले जाने को कहा जाता है।

घटनाओं का उपयोग करना

चूंकि सभी आयोनिक घटनाओं का उपयोग उसी तरह किया जा सकता है, इसलिए हम आपको दिखाएंगे कि कैसे उपयोग किया जाए on-touchघटना और आप अन्य घटनाओं के लिए केवल एक ही सिद्धांत लागू कर सकते हैं। शुरू करने के लिए, हम एक बटन बनाएंगे और एक असाइन करेंगेon-touch ईवेंट, जो कॉल करेगा onTouchFunction()

<button on-touch = "onTouchFunction()" class="button">Test</button>

फिर हम उस फंक्शन को अपने कंट्रोलर स्कोप में बनाएंगे।

$scope.onTouchFunction = function() {
   // Do something...
}

अब, जब टच इवेंट होता है onTouchFunction() बुलाया जाएगा।

यह आयोनिक निर्देश है, जो हेडर बार को जोड़ देगा।

जावास्क्रिप्ट हैडर का उपयोग करना

जावास्क्रिप्ट हेडर बार बनाने के लिए, हमें आवेदन करना होगा ion-header-barHTML फ़ाइल में निर्देश। चूंकि डिफ़ॉल्ट हैडर सफेद है, हम जोड़ देंगेtitle, इसलिए इसे सफेद पृष्ठभूमि पर दिखाया जाएगा। हम इसे अपने साथ जोड़ेंगेindex.html फ़ाइल।

<ion-header-bar>
   <h1 class = "title">Title!</h1>
</ion-header-bar>

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

स्टाइलिंग हैडर

सीएसएस हैडर बार की तरह, जावास्क्रिप्ट समकक्ष को भी इसी तरह से स्टाइल किया जा सकता है। रंग लागू करने के लिए, हमें एक रंग वर्ग के साथ जोड़ना होगाbarउपसर्ग। इसलिए, यदि हम एक नीले हेडर का उपयोग करना चाहते हैं, तो हम एक जोड़ देंगेbar-positiveकक्षा। हम शीर्षक को स्क्रीन के एक तरफ भी जोड़ सकते हैंalign-titleविशेषता। इस विशेषता के मान हो सकते हैंcenter, left या right

<ion-header-bar align-title = "left" class = "bar-positive">
   <h1 class = "title">Title!</h1>
</ion-header-bar>

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

तत्वों को जोड़ना

आप आमतौर पर अपने हेडर में कुछ तत्व जोड़ना चाहेंगे। निम्नलिखित उदाहरण से पता चलता है कि कैसे जगह हैbutton बाईं ओर और ए iconआयन हेडर-बार के दाईं ओर। आप अपने शीर्ष लेख में अन्य तत्व भी जोड़ सकते हैं।

<ion-header-bar class = "bar-positive">
   <div class = "buttons">
      <button class = "button">Button</button>
   </div>
   
   <h1 class = "title">Title!</h1>
   <div class = "buttons">
      <button class = "button icon ion-home"></button>
   </div>
</ion-header-bar>

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

सब हैडर जोड़ना

जब एक उप शीर्ष लेख बनाया जाता है bar-subheader वर्ग में जोड़ा जाता है ion-header-bar। हम एक जोड़ देंगेbar-assertive हमारे उप हैडर पर लाल रंग लगाने के लिए क्लास।

<ion-header-bar class = "bar-positive">
   <div class = "buttons">
      <button class = "button">Button</button>
   </div>
   
   <h1 class = "title">Title!</h1>
   <div class = "buttons">
      <button class = "button icon ion-home"></button>
   </div>
</ion-header-bar>

<ion-header-bar class = "bar-subheader bar-assertive">
   <h1 class = "title">Subheader</h1>
</ion-header-bar>

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

यह निर्देश स्क्रीन के नीचे एक पाद पट्टी को जोड़ेगा।

पाद का उपयोग करना

Ionic पाद लेख एक आवेदन करके जोड़ा जा सकता है ion-footer-barकक्षा। इसके साथ काम करना हेडर के साथ काम करने के समान है। हम एक शीर्षक जोड़ सकते हैं और इसे स्क्रीन के बाईं ओर, मध्य या दाईं ओर रख सकते हैंalign-titleविशेषता। उपसर्ग के साथbar, हम आयोनिक रंगों का उपयोग कर सकते हैं। केंद्र में शीर्षक के साथ लाल रंग का पाद बनाएं।

<ion-footer-bar align-title = "center" class = "bar-assertive">
   <h1 class = "title">Title!</h1>
</ion-footer-bar>

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

तत्वों को जोड़ना

हम बटन आइकन या अन्य तत्वों को जोड़ सकते हैं ion-footer-barऔर उनकी स्टाइल को लागू किया जाएगा। हमारे पाद लेख में एक बटन और एक आइकन जोड़ें।

<ion-footer-bar class = "bar-assertive">
   <div class = "buttons">
      <button class = "button">Button</button>
   </div>
  
   <h1 class = "title">Footer</h1>

   <div class = "buttons">
      <button class = "button icon ion-home"></button>
   </div>
</ion-footer-bar>

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

उप पाद जोड़ना

हमने आपको दिखाया कि उप शीर्ष लेख का उपयोग कैसे करें। उसी तरह एक उप पाद बनाया जा सकता है। यह फुटर बार के ऊपर स्थित होगा। हमें बस इतना करने की ज़रूरत है कि एक जोड़ दिया जाएbar-subfooter हमारी कक्षा ion-footer-bar तत्व।

उदाहरण के बाद, हम पाद लेख पट्टी के ऊपर उप-पाद लेख जोड़ेंगे, जिसे हमने पहले बनाया था।

<ion-footer-bar class = "bar-subfooter bar-positive">
   <h1 class = "title">Sub Footer</h1>
</ion-footer-bar>

<ion-footer-bar class = "bar-assertive">
   <div class = "buttons">
      <button class = "button">Button</button>
   </div>
  
   <h1 class = "title">Footer</h1>

   <div class = "buttons" ng-click = "doSomething()">
      <button class = "button icon ion-home"></button>
   </div>
</ion-footer-bar>

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

कीबोर्ड आयोनिक में स्वचालित विशेषताओं में से एक है। इसका मतलब यह है कि जब कीबोर्ड को खोलने की आवश्यकता होती है तो Ionic पहचान सकता है।

कीबोर्ड का उपयोग करना

कुछ फ़ंक्शंस हैं, जिन्हें डेवलपर्स Ionic कीबोर्ड के साथ काम करते समय समायोजित कर सकते हैं। जब आप कीबोर्ड खोलते समय कुछ तत्वों को छिपाना चाहते हैं, तो आप इसका उपयोग कर सकते हैंhide-on-keyboard-openकक्षा। आपको यह दिखाने के लिए कि यह कैसे काम करता है हमने इनपुट और बटन बनाया है जिसे कीबोर्ड के खुले रहने पर छिपाने की आवश्यकता है।

<label class = "item item-input">
   <input type = "text" placeholder = "Input 1">
</label>

<button class = "button button-block hide-on-keyboard-open">
   button
</button>

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

अब, जब हम इनपुट फ़ील्ड पर टैप करते हैं, तो कीबोर्ड अपने आप खुल जाएगा और बटन छिप जाएगा।

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

जब हम नीले रूप पर टैप करते हैं, तो आयोनिक हमारी स्क्रीन को समायोजित करेगा, इसलिए नीला रूप हमेशा दिखाई देता है।

Note - यह तभी काम करेगा जब स्क्रीन एक निर्देश के भीतर हो, जिसमें ए Scroll View। यदि आप किसी Ionic टेम्प्लेट में से एक से शुरू करते हैं, तो आप देखेंगे कि सभी टेम्प्लेट उपयोग करते हैंion-content अन्य स्क्रीन तत्वों के लिए एक कंटेनर के रूप में निर्देश दें, इसलिए स्क्रॉल दृश्य हमेशा लागू किया जाता है।

हमने पहले अध्याय में Ionic CSS सूची तत्वों पर चर्चा की है। इस अध्याय में, हम आपको जावास्क्रिप्ट सूची दिखाएंगे। वे हमें कुछ नई सुविधाओं का उपयोग करने की अनुमति देते हैंswipe, drag तथा remove

सूची का उपयोग करना

सूचियों और वस्तुओं को प्रदर्शित करने के लिए उपयोग किए जाने वाले निर्देश हैं ion-list तथा ion-item जैसा की नीचे दिखाया गया।

<ion-list>
   <ion-item>
      Item 1 
   </ion-item>
	
   <ion-item>
      Item 2 
   </ion-item>
	
   <ion-item>
      Item 3  
   </ion-item>
</ion-list>

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

बटन हटाएँ

इस बटन का उपयोग करके जोड़ा जा सकता है ion-delete-buttonनिर्देश। आप अपनी इच्छानुसार किसी भी आइकन वर्ग का उपयोग कर सकते हैं। चूंकि हम हमेशा डिलीट बटन नहीं दिखाना चाहते हैं, क्योंकि उपयोगकर्ता गलती से इसे टैप कर सकते हैं और डिलीट प्रक्रिया को ट्रिगर कर सकते हैं, हम इसे जोड़ सकते हैंshow-delete को विशेषता ion-list और इसे के साथ कनेक्ट करें ng-model

निम्नलिखित उदाहरण में, हम इसका उपयोग करेंगे ion-toggleनमूने के तौर पर। जब टॉगल डिलीट होता है, तो बटन हमारी सूची में दिखाई देंगे।

<ion-list show-delete = "showDelete1">
   <ion-item>
      <ion-delete-button class = "ion-minus-circled"></ion-delete-button>
      Item 1
   </ion-item>
	
   <ion-item>
      <ion-delete-button class = "ion-minus-circled"></ion-delete-button>
      Item 2
   </ion-item>
</ion-list>

<ion-toggle ng-model = "showDelete2">
   Show Delete 2
</ion-toggle>

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

राउटर बटन

आयोडर बटन के लिए आयोनिक निर्देश है ion-reorder-button। हमने जो तत्व बनाया है, उसमें एon-reorder जब भी उपयोगकर्ता इस तत्व को खींच रहा है, तो विशेषता हमारे नियंत्रक से फ़ंक्शन को ट्रिगर करेगी।

<ion-list show-reorder = "true">
   <ion-item ng-repeat = "item in items">
      Item {{item.id}}
      <ion-reorder-button class = "ion-navicon" 
         on-reorder = "moveItem(item, $fromIndex, $toIndex)"></ion-reorder-button> </ion-item> </ion-list> $scope.items = [
   {id: 1},
   {id: 2},
   {id: 3},
   {id: 4}
];

$scope.moveItem = function(item, fromIndex, toIndex) { $scope.items.splice(fromIndex, 1);
   $scope.items.splice(toIndex, 0, item);
};

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

जब हम दाईं ओर आइकन पर क्लिक करते हैं, तो हम तत्व को खींच सकते हैं और इसे सूची में किसी अन्य स्थान पर स्थानांतरित कर सकते हैं।

विकल्प बटन

विकल्प बटन एक का उपयोग कर बनाया गया है ion-option-buttonनिर्देश। ये बटन तब दिखाए जाते हैं जब सूची आइटम बाईं ओर स्वाइप की जाती है और हम आइटम तत्व को दाईं ओर स्वाइप करके इसे फिर से छिपा सकते हैं।

आप निम्न उदाहरण में देख सकते हैं कि दो बटन हैं, जो छिपे हुए हैं।

<ion-list>
   <ion-item>
      Item with two buttons...
      <ion-option-button class = "button-positive">Button 1</ion-option-button>
      <ion-option-button class = "button-assertive">Button 2</ion-option-button>
   </ion-item>
</ion-list>

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

जब हम आइटम तत्व को बाईं ओर स्वाइप करते हैं, तो टेक्स्ट लेफ्ट हो जाएगा और राइट साइड में बटन दिखाई देंगे।

अन्य कार्य

collection-repeat फ़ंक्शन का एक अद्यतन संस्करण है AngularJS ng-repeat directive। यह केवल स्क्रीन पर दिखाई देने वाले तत्वों को प्रस्तुत करेगा और स्क्रॉल करते ही शेष अपडेट हो जाएगा। जब आप बड़ी सूचियों के साथ काम कर रहे हों तो यह एक महत्वपूर्ण प्रदर्शन सुधार है। इस निर्देश के साथ जोड़ा जा सकता हैitem-width तथा item-height सूची आइटम के आगे अनुकूलन के लिए विशेषताएँ।

आपकी सूची के अंदर छवियों के साथ काम करने के लिए कुछ अन्य उपयोगी विशेषताएं हैं। item-render-bufferफ़ंक्शन उन मदों की संख्या का प्रतिनिधित्व करता है जो दृश्यमान वस्तुओं के बाद लोड किए जाते हैं। यह मूल्य जितना अधिक होगा, उतनी ही वस्तुओं को पहले से लोड किया जाएगा। force-refresh-imagesफ़ंक्शन स्क्रॉल करते समय छवियों के स्रोत के साथ एक समस्या को ठीक करेगा। ये दोनों वर्ग नकारात्मक तरीके से प्रदर्शन को प्रभावित करेंगे।

आयोनिक लोडिंग उपयोगकर्ताओं को दिखाए जाने पर किसी भी इंटरैक्शन को अक्षम कर देगा और जब आवश्यक हो तब इसे फिर से सक्षम करेगा।

लोड हो रहा है का उपयोग करना

लोड हो रहा है नियंत्रक के अंदर शुरू हो रहा है। सबसे पहले, हमें इंजेक्शन लगाने की आवश्यकता है$ionicLoadingनिर्भरता के रूप में हमारे नियंत्रक में। उसके बाद, हमें कॉल करने की आवश्यकता है$ionicLoading.show()विधि और लोडिंग दिखाई देगी। इसे अक्षम करने के लिए, वहाँ एक है$ionicLoading.hide() तरीका।

नियंत्रक

.controller('myCtrl', function($scope, $ionicLoading) {
   $scope.showLoading = function() { $ionicLoading.show({
         template: 'Loading...'
      });
   };

   $scope.hideLoading = function(){ $ionicLoading.hide();
   };
});

HTML कोड

<button class = "button button-block" ng-click = "showLoading()"></button>

जब उपयोगकर्ता बटन टैप करता है, तो लोडिंग दिखाई देगी। आप आमतौर पर लोडिंग को छुपाना चाहेंगे कुछ समय लेने के बाद कार्यक्षमता समाप्त हो जाती है।

लोडिंग के साथ काम करते समय कुछ अन्य विकल्प मापदंडों का उपयोग किया जा सकता है। स्पष्टीकरण नीचे दी गई तालिका में दिखाया गया है।

विकल्प पैरामीटर लोड हो रहे हैं

विकल्प प्रकार विवरण
templateUrl तार लोडिंग इंडिकेटर के रूप में HTML टेम्पलेट को लोड करने के लिए उपयोग किया जाता है।
क्षेत्र वस्तु लोडिंग के लिए कस्टम स्कोप पास करने के लिए उपयोग किया जाता है। डिफ़ॉल्ट $ rootScope है।
noBackdrop बूलियन पृष्ठभूमि को छिपाने के लिए उपयोग किया जाता है।
hideOnStateChange बूलियन जब स्थिति बदली जाती है तो लोडिंग को छिपाने के लिए उपयोग किया जाता है।
विलंब संख्या मिलीसेकंड में संकेतक दिखाने में देरी करते थे।
अवधि संख्या मिलीसेकंड में कुछ समय बाद संकेतक को छिपाने के लिए उपयोग किया जाता है। के स्थान पर उपयोग किया जा सकता हैhide() तरीका।

कॉन्फ़िगरेशन लोड हो रहा है

Ionic कॉन्फिगरेशन का उपयोग उन विकल्पों को कॉन्फ़िगर करने के लिए किया जाता है, जिनका आप सभी में उपयोग करना चाहते हैं $ionicLoading पूरे ऐप में सेवाएं।

यह प्रयोग करके किया जा सकता है $ionicLoadingConfig। चूंकि स्थिरांक को मुख्य ऐप मॉड्यूल में जोड़ा जाना चाहिए, अपने को खोलेंapp.js फ़ाइल और मॉड्यूल घोषणा के बाद अपने निरंतर जोड़ें।

.constant('$ionicLoadingConfig', {
   template: 'Default Loading Template...'
})

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

जब आयोनिक मोडल सक्रिय होता है, तो सामग्री फलक नियमित सामग्री के ऊपर दिखाई देगा। मोडल मूल रूप से अधिक कार्यात्मकता के साथ बड़ा पॉपअप है। मोडल डिफ़ॉल्ट रूप से पूरी स्क्रीन को कवर करेगा लेकिन यह आपके इच्छित तरीके से अनुकूलित किया जा सकता है।

मोडल का उपयोग करना

आयनिक में मोडल को लागू करने के दो तरीके हैं। एक तरीका अलग टेम्पलेट जोड़ना है और दूसरा इसे नियमित HTML फ़ाइल के शीर्ष पर, अंदर जोड़ना हैscriptटैग। पहली चीज जो हमें करने की ज़रूरत है वह है कि हम अपने मॉड्यूलर को कोणीय निर्भरता इंजेक्शन का उपयोग करके कनेक्ट करें। फिर हमें एक मोडल बनाने की जरूरत है। हम दायरे में पास होंगे और हमारे मोडल में एनीमेशन जोड़ेंगे।

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

नियंत्रक कोड

.controller('MyController', function($scope, $ionicModal) {
   $ionicModal.fromTemplateUrl('my-modal.html', { scope: $scope,
      animation: 'slide-in-up'
   }).then(function(modal) {
      $scope.modal = modal; }); $scope.openModal = function() {
      $scope.modal.show(); }; $scope.closeModal = function() {
      $scope.modal.hide(); }; //Cleanup the modal when we're done with it! $scope.$on('$destroy', function() {
      $scope.modal.remove(); }); // Execute action on hide modal $scope.$on('modal.hidden', function() { // Execute action }); // Execute action on remove modal $scope.$on('modal.removed', function() {
      // Execute action
   });
});

HTML कोड

<script id = "my-modal.html" type = "text/ng-template">
   <ion-modal-view>
      <ion-header-bar>
         <h1 class = "title">Modal Title</h1>
      </ion-header-bar>
		
      <ion-content>
         <button class = "button icon icon-left ion-ios-close-outline"
            ng-click = "closeModal()">Close Modal</button>
      </ion-content>
   </ion-modal-view>
</script>

जिस तरह से हमने पिछले उदाहरण में दिखाया था, जब script कुछ मौजूदा HTML फ़ाइल के अंदर हमारे मोडल के लिए टैग के रूप में उपयोग किया जाता है।

दूसरा तरीका है कि आप अंदर एक नई टेम्पलेट फ़ाइल बनाएँ templatesफ़ोल्डर। हम अपने अंतिम उदाहरण में उसी कोड का उपयोग करेंगे, लेकिन हम इसे हटा देंगेscript टैग और हमें भी बदलने की जरूरत है fromTemplateUrl नए बनाए गए टेम्पलेट के साथ मोडल कनेक्ट करने के लिए नियंत्रक में।

नियंत्रक कोड

.controller('MyController', function($scope, $ionicModal) { $ionicModal.fromTemplateUrl('templates/modal-template.html', {
      scope: $scope, animation: 'slide-in-up', }).then(function(modal) { $scope.modal = modal;
   });
	
   $scope.openModal = function() { $scope.modal.show();
   };
	
   $scope.closeModal = function() { $scope.modal.hide();
   };
	
   //Cleanup the modal when we're done with it!
   $scope.$on('$destroy', function() { $scope.modal.remove();
   });
	
   // Execute action on hide modal
   $scope.$on('modal.hidden', function() {
      // Execute action
   });
	
   // Execute action on remove modal
   $scope.$on('modal.removed', function() {
      // Execute action
   });
});

HTML कोड

<ion-modal-view>
   <ion-header-bar>
      <h1 class = "title">Modal Title</h1>
   </ion-header-bar>
	
   <ion-content>
      <button class = "button icon icon-left ion-ios-close-outline"
         ng-click = "closeModal()">Close Modal</button>
   </ion-content>
</ion-modal-view>

HTML इनलाइन डालने से आयोनिक मोडल का उपयोग करने का तीसरा तरीका है। हम उपयोग करेंगेfromTemplate के बजाय कार्य करते हैं fromTemplateUrl

नियंत्रक कोड

.controller('MyController', function($scope, $ionicModal) {
   $scope.modal = $ionicModal.fromTemplate( '<ion-modal-view>' +
      ' <ion-header-bar>' +
         '<h1 class = "title">Modal Title</h1>' +
      '</ion-header-bar>' +
		
      '<ion-content>'+
         '<button class = "button icon icon-left ion-ios-close-outline"
            ng-click = "closeModal()">Close Modal</button>' +
      '</ion-content>' +
		
   '</ion-modal-view>', {
      scope: $scope, animation: 'slide-in-up' }) $scope.openModal = function() {
      $scope.modal.show(); }; $scope.closeModal = function() {
      $scope.modal.hide(); }; //Cleanup the modal when we're done with it! $scope.$on('$destroy', function() {
      $scope.modal.remove(); }); // Execute action on hide modal $scope.$on('modal.hidden', function() { // Execute action }); // Execute action on remove modal $scope.$on('modal.removed', function() {
      // Execute action
   });
});

तीनों उदाहरणों का समान प्रभाव होगा। हम ट्रिगर करने के लिए एक बटन बनाएंगे$ionicModal.show() मोडल खोलने के लिए।

HTML कोड

<button class = "button" ng-click = "openModal()"></button>

जब हम मोडल खोलते हैं, तो उसमें एक बटन होता है जिसका उपयोग इसे बंद करने के लिए किया जाएगा। हमने यह बटन एक HTML टेम्पलेट में बनाया है।

मोडल ऑप्टिमाइज़ेशन के अन्य विकल्प भी हैं। हमने पहले ही दिखाया कि कैसे उपयोग करना हैscope तथा animation। निम्न तालिका अन्य विकल्प दिखाती है।

विकल्प प्रकार विस्तार
focusFirstInput बूलियन यह मोडल के पहले इनपुट को फोकस करेगा।
backdropClickToClose बूलियन बैकड्रॉप के टैप करने पर यह मोडल को बंद करने में सक्षम होगा। डिफ़ॉल्ट मान सत्य है।
hardwareBackButtonClose बूलियन हार्डवेयर बैक बटन पर क्लिक करने पर यह मोडल को बंद करने में सक्षम होगा। डिफ़ॉल्ट मान सत्य है।

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

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

नेविगेशन में कॉन्फ़िगर किया जा सकता है app.jsफ़ाइल। यदि आप Ionic में से किसी एक टेम्पलेट का उपयोग कर रहे हैं, तो आप इस पर ध्यान देंगे$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
});

यह एक ऐसा दृश्य है जो नियमित दृश्य के ऊपर दिखाई देगा।

पॉपओवर का उपयोग करना

एक पॉपओवर का उपयोग करके बनाया जा सकता है 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 जब हार्डवेयर बैक बटन दबाया जाता है तो पॉपओवर को बंद करने के लिए उपयोग किया जाता है।
दिखाने ($ घटना) $ घटना वादा जब पॉपओवर पूरा हो रहा है तब हल किया गया।
छिपाना() / वादा हल हो गया जब पॉपओवर को छुपाया गया।
हटाना() / वादा जब पॉपओवर समाप्त हो रहा है तब हल किया गया।
दिखाया गया है() / बूलियन यदि पॉपओवर दिखाया गया है या गलत है तो सही है।

इस सेवा का उपयोग नियमित दृश्य के शीर्ष पर पॉपअप विंडो बनाने के लिए किया जाता है, जिसका उपयोग उपयोगकर्ताओं के साथ बातचीत के लिए किया जाएगा। चार प्रकार के पॉपअप हैं-show, confirm, alert तथा prompt

शो पॉपअप का उपयोग करना

यह पॉपअप सबसे जटिल है। पॉपअप को ट्रिगर करने के लिए, हमें इंजेक्ट करने की आवश्यकता है$ionicPopup हमारे नियंत्रक के लिए सेवा और फिर एक ऐसा तरीका जोड़ें जो इस मामले में हम जिस पॉपअप का उपयोग करना चाहते हैं, उसे ट्रिगर करेंगे $ionicPopup.show()onTap(e) फ़ंक्शन को जोड़ने के लिए उपयोग किया जा सकता है e.preventDefault()विधि, जो पॉपअप को खुला रखेगा, यदि इनपुट में कोई परिवर्तन लागू नहीं होता है। जब पॉपअप बंद हो जाता है, तो वादा किया गया ऑब्जेक्ट हल हो जाएगा।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicPopup) {
   // When button is clicked, the popup will be shown...
   $scope.showPopup = function() { $scope.data = {}
    
      // Custom popup
      var myPopup = $ionicPopup.show({ template: '<input type = "text" ng-model = "data.model">', title: 'Title', subTitle: 'Subtitle', scope: $scope,
			
         buttons: [
            { text: 'Cancel' }, {
               text: '<b>Save</b>',
               type: 'button-positive',
               onTap: function(e) {
						
                  if (!$scope.data.model) { //don't allow the user to close unless he enters model... e.preventDefault(); } else { return $scope.data.model;
                  }
               }
            }
         ]
      });

      myPopup.then(function(res) {
         console.log('Tapped!', res);
      });    
   };
})

HTML कोड

<button class = "button" ng-click = "showPopup()">Add Popup Show</button>

आपने शायद उपर्युक्त उदाहरण में देखा कि कुछ नए विकल्पों का उपयोग किया गया था। निम्न तालिका उन सभी विकल्पों और उनके उपयोग के मामले की व्याख्या करेगी।

पॉपअप विकल्प दिखाएँ

विकल्प प्रकार विवरण
टेम्पलेट तार पॉपअप के इनलाइन HTML टेम्पलेट।
templateUrl तार HTML टेम्पलेट का URL।
शीर्षक तार पॉपअप का शीर्षक।
उपशीर्षक तार पॉपअप का उपशीर्षक।
cssClass तार पॉपअप का CSS क्लास नाम।
क्षेत्र क्षेत्र पॉपअप का एक दायरा।
बटन सरणी [वस्तु] बटन जो पॉपअप के पाद में रखे जाएंगे। वे अपने स्वयं के गुणों और विधियों का उपयोग कर सकते हैं।text बटन के ऊपर प्रदर्शित होता है, type बटन के लिए इओनिक वर्ग का उपयोग किया जाता है, onTapबटन टैप होने पर फ़ंक्शन चालू हो जाता है। मूल्य वापस करने से दिए गए मूल्य के साथ वादा करने का कारण होगा।

पॉपअप की पुष्टि करना

एक पुष्टि पॉपअप Ionic पॉपअप का सरल संस्करण है। इसमें कैंसिल और ओके बटन हैं जो उपयोगकर्ता संबंधित कार्यक्षमता को ट्रिगर करने के लिए दबा सकते हैं। यह वादा किए गए ऑब्जेक्ट को वापस करता है जो तब हल किया जाता है जब एक बटन दबाया जाता है।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicPopup) {
   // When button is clicked, the popup will be shown...
   $scope.showConfirm = function() { var confirmPopup = $ionicPopup.confirm({
         title: 'Title',
         template: 'Are you sure?'
      });

      confirmPopup.then(function(res) {
         if(res) {
            console.log('Sure!');
         } else {
            console.log('Not sure!');
         }
      });
	};
})

HTML कोड

<button class = "button" ng-click = "showConfirm()">Add Popup Confirm</button>

निम्न तालिका उन विकल्पों की व्याख्या करती है जिनका उपयोग इस पॉपअप के लिए किया जा सकता है।

पॉपअप विकल्पों की पुष्टि करें

विकल्प प्रकार विवरण
टेम्पलेट तार पॉपअप के इनलाइन HTML टेम्पलेट।
templateUrl तार HTML टेम्पलेट का URL।
शीर्षक तार पॉपअप का शीर्षक।
उपशीर्षक तार पॉपअप का उपशीर्षक।
cssClass तार पॉपअप का CSS क्लास नाम।
cancelText तार रद्द करें बटन के लिए पाठ।
cancelType तार रद्द करें बटन का आयोनिक बटन प्रकार।
okText तार ठीक बटन के लिए पाठ।
okType तार ओके बटन का आयोनिक बटन प्रकार।

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

एक अलर्ट एक साधारण पॉपअप है जिसका उपयोग उपयोगकर्ता को सतर्क सूचना प्रदर्शित करने के लिए किया जाता है। इसमें केवल एक बटन है जो पॉपअप को बंद करने और पॉपअप की वादा की गई वस्तु को हल करने के लिए उपयोग किया जाता है।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicPopup) {
   $scope.showAlert = function() { var alertPopup = $ionicPopup.alert({
         title: 'Title',
         template: 'Alert message'
      });

      alertPopup.then(function(res) {
         // Custom functionality....
      });
   };
})

HTML कोड

<button class = "button" ng-click = "showAlert()">Add Popup Alert</button>

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

निम्न तालिका उन विकल्पों को दिखाती है जिनका उपयोग अलर्ट पॉपअप के लिए किया जा सकता है।

अलर्ट पॉपअप विकल्प

विकल्प प्रकार विवरण
टेम्पलेट तार पॉपअप के इनलाइन HTML टेम्पलेट।
templateUrl तार HTML टेम्पलेट का URL।
शीर्षक तार पॉपअप का शीर्षक।
उपशीर्षक तार पॉपअप का उपशीर्षक।
cssClass तार पॉपअप का CSS क्लास नाम।
okText तार ठीक बटन के लिए पाठ।
okType तार ओके बटन का आयोनिक बटन प्रकार।

शीघ्र पॉपअप का उपयोग करना

अंतिम ईओण पॉपअप जो आयोनिक का उपयोग करके बनाया जा सकता है prompt। इसमें एक ठीक बटन है जो इनपुट से मूल्य के साथ वादा करता है और रद्द बटन जो अपरिभाषित मूल्य के साथ हल करता है।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicPopup) {
   $scope.showPrompt = function() { var promptPopup = $ionicPopup.prompt({
         title: 'Title',
         template: 'Template text',
         inputType: 'text',
         inputPlaceholder: 'Placeholder'
      });
        
      promptPopup.then(function(res) {
         console.log(res);
      });
   };
})

HTML कोड

<button class = "button" ng-click = "showPrompt()">Add Popup Prompt</button>

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

निम्न तालिका उन विकल्पों को दिखाती है जिनका उपयोग शीघ्र पॉपअप के लिए किया जा सकता है।

शीघ्र पॉपअप विकल्प

विकल्प प्रकार विवरण
टेम्पलेट तार पॉपअप के इनलाइन HTML टेम्पलेट।
templateUrl तार HTML टेम्पलेट का URL।
शीर्षक तार पॉपअप का शीर्षक।
उपशीर्षक तार पॉपअप का उपशीर्षक।
cssClass तार पॉपअप का CSS क्लास नाम।
निवेष का प्रकार तार इनपुट के लिए प्रकार।
inputPlaceholder तार इनपुट के लिए एक प्लेसहोल्डर।
cancelText तार रद्द करें बटन के लिए पाठ।
cancelType तार रद्द करें बटन का आयोनिक बटन प्रकार।
okText तार ठीक बटन के लिए पाठ।
okType तार ओके बटन का आयोनिक बटन प्रकार।

आयनिक ऐप्स में हेरफेर स्क्रॉल करने के लिए उपयोग किए जाने वाले तत्व को कहा जाता है 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();

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

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

पहला तत्व जो हमें चाहिए 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();

स्लाइड बॉक्स में वे पृष्ठ होते हैं जिन्हें सामग्री स्क्रीन को स्वाइप करके बदला जा सकता है।

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

स्लाइड बॉक्स का उपयोग सरल है। आपको बस जोड़ने की जरूरत हैion-slide-box एक कंटेनर के रूप में और ion-slideउस कंटेनर के अंदर बॉक्स क्लास के साथ। बेहतर दृश्यता के लिए हम अपने बॉक्स में ऊंचाई और सीमा जोड़ेंगे।

HTML कोड

<ion-slide-box>

   <ion-slide>
      <div class = "box box1">
         <h1>Box 1</h1>
      </div>
   </ion-slide>

   <ion-slide>
      <div class = "box box2">
         <h1>Box 2</h1>
      </div>
   </ion-slide>

   <ion-slide>
      <div class = "box box3">
         <h1>Box 3</h1>
      </div>
   </ion-slide>

</ion-slide-box>

.box1, box2, box3 {
   height: 300px;
   border: 2px solid blue;
}

आउटपुट निम्न स्क्रीनशॉट में दिखाया जाएगा -

हम सामग्री को दाईं ओर खींचकर बॉक्स को बदल सकते हैं। हम पिछले बॉक्स को दिखाने के लिए बाईं ओर भी खींच सकते हैं।

स्लाइड बॉक्स के व्यवहार को नियंत्रित करने के लिए उपयोग की जा सकने वाली कुछ विशेषताओं का उल्लेख निम्न तालिका में किया गया है।

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

गुण प्रकार विवरण
करता है-जारी रखने के लिए बूलियन पहले या आखिरी बॉक्स तक पहुँचने पर बॉक्स लूप को स्लाइड करना चाहिए।
स्वत: प्ले बूलियन स्लाइड बॉक्स को स्वचालित रूप से स्लाइड करना चाहिए।
स्लाइड अंतराल संख्या मिलीसेकंड में ऑटो स्लाइड परिवर्तन के बीच का समय मूल्य। डिफ़ॉल्ट मान 4000 है।
शो-पेजर बूलियन पेजर दिखना चाहिए।
पेजर क्लिक अभिव्यक्ति जब कोई पेजर टैप किया जाता है (यदि पेजर दिखाई देता है) तो कॉल किया जाता है। $index का उपयोग विभिन्न स्लाइडों के साथ मिलान करने के लिए किया जाता है।
ऑन-स्लाइड-बदल अभिव्यक्ति स्लाइड बदलने पर कॉल किया जाता है। $index का उपयोग विभिन्न स्लाइडों के साथ मिलान करने के लिए किया जाता है।
सक्रिय स्लाइड अभिव्यक्ति वर्तमान स्लाइड सूचकांक को बांधने के लिए एक मॉडल के रूप में उपयोग किया जाता है।
प्रतिनिधि-संभाल तार स्लाइड बॉक्स पहचान के लिए उपयोग किया जाता है $ionicSlideBoxDelegate

स्लाइड बॉक्स प्रतिनिधि

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

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicSlideBoxDelegate) {
   $scope.nextSlide = function() { $ionicSlideBoxDelegate.next();
   }
})

HTML कोड

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

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

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

तरीका मापदंडों प्रकार विवरण
स्लाइड (पैरामीटर 1, पैरामीटर 2) तेज़ी से संख्या, संख्या पैरामीटर to करने के लिए स्लाइड करने के लिए सूचकांक का प्रतिनिधित्व करता है। speed यह निर्धारित करता है कि मिलीसेकंड में परिवर्तन कितना तेज है।
enableSlide (parameter1) shouldEnable बूलियन स्लाइडिंग को अक्षम करने या अक्षम करने के लिए उपयोग किया जाता है।
पिछले (parameter1) स्पीड संख्या परिवर्तन करने के लिए मिलिसेकंड में मूल्य लेना चाहिए।
रुकें() / / स्लाइडिंग को रोकने के लिए उपयोग किया जाता है।
शुरू() / / रपट शुरू करने के लिए इस्तेमाल किया।
currentIndex () / संख्या क्यूरेंट स्लाइड का इंडेक्स।
slidesCount () / संख्या स्लाइड्स की कुल संख्या लौटाता है।
$ GetByHandle (parameter1) हैंडल तार एक ही हैंडल के साथ विशेष स्लाइड बॉक्स में विधियों को जोड़ने के लिए उपयोग किया जाता है। $ionicSlideBoxDelegate. $getByHandle('my-handle').start();

टैब किसी भी नेविगेशन प्रकार या आपके ऐप के अंदर अलग-अलग पृष्ठों का चयन करने के लिए एक उपयोगी पैटर्न है। Android उपकरणों के लिए स्क्रीन के शीर्ष पर और IOS उपकरणों के लिए नीचे एक ही टैब दिखाई देगा।

टैब का उपयोग करना

टैब का उपयोग करके ऐप में जोड़ा जा सकता है ion-tabs एक कंटेनर तत्व के रूप में और ion-tabएक सामग्री तत्व के रूप में। हम इसे जोड़ देंगेindex.html, लेकिन आप इसे अपने ऐप के अंदर किसी भी HTML फ़ाइल में जोड़ सकते हैं। बस इसे अंदर नहीं जोड़ना सुनिश्चित करेंion-content सीएसएस मुद्दों से बचने के लिए जो इसके साथ आता है।

index.html कोड

<ion-tabs class = "tabs-icon-only">

   <ion-tab title = "Home" icon-on = "ion-ios-filing" 
      icon-off = "ion-ios-filing-outline"></ion-tab>

   <ion-tab title = "About" icon-on = "ion-ios-home" 
      icon-off = "ion-ios-home-outline"></ion-tab>

   <ion-tab title = "Settings" icon-on = "ion-ios-star" 
      icon-off = "ion-ios-star-outline"></ion-tab>

</ion-tabs>

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

के लिए एपीआई उपलब्ध है ion-tabतत्वों। आप इसे उन विशेषताओं के रूप में जोड़ सकते हैं जैसा कि ऊपर उदाहरण में दिखाया गया है जहां हमने उपयोग किया थाtitle, icon-on तथा icon-off। अंतिम दो का उपयोग शेष टैब से चयनित टैब को अलग करने के लिए किया जाता है। यदि आप ऊपर की छवि को देखते हैं, तो आप देख सकते हैं कि पहला टैब चुना गया है। आप निम्न तालिका में बाकी विशेषताओं की जांच कर सकते हैं।

टैब विशेषताएँ

गुण प्रकार विवरण
शीर्षक तार टैब का शीर्षक।
href तार टैब नेविगेशन के लिए प्रयुक्त लिंक।
आइकन तार टैब का आइकन।
आइकन पर तार चयनित होने पर टैब का आइकन।
आइकन बंद तार चयनित नहीं होने पर टैब का आइकन।
बिल्ला अभिव्यक्ति टैब के लिए बैज।
बिल्ला शैली अभिव्यक्ति टैब के लिए बैज शैली।
ऑन-चयन अभिव्यक्ति टैब चुने जाने पर कॉल किया जाता है
ऑन-अचयनित अभिव्यक्ति टैब के अचयनित होने पर कॉल किया जाता है
छिपा हुआ अभिव्यक्ति टैब को छिपाने के लिए उपयोग किया जाता है।
विकलांग अभिव्यक्ति टैब को अक्षम करने के लिए उपयोग किया जाता है।

ऐप के अंदर सभी टैब के आसान नियंत्रण के लिए टैब्स की अपनी प्रतिनिधि सेवा भी है। इसे कंट्रोलर में इंजेक्ट किया जा सकता है और इसमें कई तरीके हैं, जो निम्न तालिका में दिखाए गए हैं।

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

तरीका मापदंडों प्रकार विवरण
SelectedIndex () / संख्या चयनित टैब का सूचकांक लौटाता है।
$ GetByHandle (parameter1) हैंडल तार एक ही हैंडल के साथ विशेष टैब दृश्य में विधियों को जोड़ने के लिए उपयोग किया जाता है। हैंडल को जोड़ा जा सकता हैion-tabs का उपयोग करके delegate-handle = "my-handle" विशेषता। $ionicTabsDelegate.$getByHandle('my-handle').selectedIndex();

कॉर्डोवा प्रदान करता है ngCordova, जो विशेष रूप से AngularJS के साथ काम करने के लिए डिज़ाइन किए गए रैपर से बना है।

एनकोर्डोवा स्थापित करना

जब आप इओनिक ऐप शुरू करते हैं, तो आप देखेंगे कि यह उपयोग कर रहा है bower। इसका उपयोग एनकोर्डोवा प्लगइन्स के प्रबंधन के लिए किया जा सकता है। यदि आपके पास bower इंस्टॉल है, तो इस चरण को छोड़ दें, यदि आपके पास यह नहीं है, तो आप इसे कमांड प्रॉम्प्ट विंडो में स्थापित कर सकते हैं।

C:\Users\Username\Desktop\MyApp> npm install -g bower

अब हमें स्थापित करने की आवश्यकता है ngCordova। कमांड प्रॉम्प्ट विंडो में अपना ऐप खोलें। निम्न उदाहरण का उपयोग उस ऐप के लिए किया जाता है जो डेस्कटॉप पर स्थित है और जिसका नाम हैMyApp

C:\Users\Username\Desktop\MyApp> bower install ngCordova

इसके बाद, हमें अपने ऐप में ngCordova को शामिल करना होगा। खुला हुआindex.htmlफ़ाइल और निम्नलिखित स्क्रिप्ट जोड़ें। इससे पहले इन लिपियों को जोड़ना महत्वपूर्ण हैcordova.js और बाद में ionic स्क्रिप्ट।

<script src = "lib/ngCordova/dist/ng-cordova.js"></script>

अब, हमें एनगॉर्डोवा को कोणीय निर्भरता के रूप में इंजेक्ट करने की आवश्यकता है। अपनी app.js फ़ाइल खोलें और एनकोर्डोवा को कोणीय मॉड्यूल में जोड़ें। यदि आपने ईओनिक टेम्प्लेट एप्लिकेशन में से किसी एक का उपयोग किया है, तो आप देखेंगे कि इसमें आयनिक, नियंत्रक और सेवाएं शामिल हैं। उस स्थिति में, आप सरणी के अंत में बस ngCordova जोड़ देंगे।

angular.module('myApp', ['ngCordova'])

आप हमेशा निम्न कमांड टाइप करके पहले से इंस्टॉल किए गए प्लगइन्स की जांच कर सकते हैं।

C:\Users\Username\Desktop\MyApp> cordova plugins ls

अब, हम कॉर्डोवा प्लगइन्स का उपयोग कर सकते हैं। आप यहां अन्य सभी प्लगइन्स की जांच कर सकते हैं ।

Cordova AdMob प्लगइन का उपयोग विज्ञापनों को मूल रूप से एकीकृत करने के लिए किया जाता है। हम उपयोग करेंगेadmobpro इस चैप्टर में प्लगिन, चूंकि कॉम्प्रोब्रिट डेप्रिसिएटेड है।

AdMob का उपयोग करना

अपने ऐप में विज्ञापनों का उपयोग करने में सक्षम होने के लिए, आपको एक बैनर बनाने और साइन अप करने की आवश्यकता है। जब आप ऐसा करेंगे, तो आपको एकAd Publisher ID.चूंकि ये चरण Ionic ढांचे का हिस्सा नहीं हैं, इसलिए हम यहां इसकी व्याख्या नहीं करेंगे। आप Google समर्थन टीम के चरणों का अनुसरण कर सकते हैं ।

आपको एंड्रॉइड या आईओएस प्लेटफॉर्म स्थापित करने की भी आवश्यकता होगी, क्योंकि कॉर्डोवा प्लगइन्स केवल देशी प्लेटफार्मों पर काम करते हैं। हमने पहले ही चर्चा की है कि हमारे पर्यावरण सेटअप अध्याय में यह कैसे किया जाए।

AdMob प्लगइन कमांड प्रॉम्प्ट विंडो में स्थापित किया जा सकता है।

C:\Users\Username\Desktop\MyApp> cordova plugin add cordova-plugin-admobpro

अब जब हमने प्लगइन स्थापित किया है, तो हमें यह जांचने की आवश्यकता है कि क्या डिवाइस तैयार है इससे पहले कि हम इसका उपयोग करने में सक्षम हैं। यही कारण है कि हमें निम्नलिखित कोड को इसमें जोड़ना होगा$ionicPlatform.ready के अंदर कार्य करते हैं app.js

if( ionic.Platform.isAndroid() )  { 
   admobid = { // for Android
      banner: 'ca-app-pub-xxx/xxx' // Change this to your Ad Unit Id for banner...
   };

   if(AdMob) 
      AdMob.createBanner( {
         adId:admobid.banner, 
         position:AdMob.AD_POSITION.BOTTOM_CENTER, 
         autoShow:true
      } );
}

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

आईओएस या विंडोज फोन के लिए एक ही कोड लागू किया जा सकता है। आप इन प्लेटफार्मों के लिए केवल एक अलग आईडी का उपयोग करेंगे। एक बैनर के बजाय, आप अंतरालीय विज्ञापनों का उपयोग कर सकते हैं जो पूरी स्क्रीन को कवर करेंगे।

AdMob तरीके

निम्न तालिका में ऐसे तरीकों को दिखाया गया है जिनका उपयोग कॉम्बो के साथ किया जा सकता है।

तरीका मापदंडों विवरण
createBanner (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) adId / विकल्प, सफलता, असफल बैनर बनाने के लिए उपयोग किया जाता है।
removeBanner () / बैनर हटाने के लिए इस्तेमाल किया।
showBanner (parameter1) पद बैनर दिखाने के लिए इस्तेमाल किया।
showBannerAtXY (पैरामीटर 1, पैरामीटर 2) एक्स, वाई निर्दिष्ट स्थान पर बैनर दिखाने के लिए उपयोग किया जाता है।
hideBanner (); / बैनर छिपाने के लिए उपयोग किया जाता है।
readyInterstitial (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) adId / विकल्प, सफलता, असफल अंतरालीय तैयार करने के लिए उपयोग किया जाता है।
showInterstitial (); / इंटरस्टीशियल दिखाने के लिए इस्तेमाल किया जाता है।
setOptions (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) विकल्प, सफलता, असफल अन्य विधियों के लिए डिफ़ॉल्ट मान सेट करने के लिए उपयोग किया जाता है।

AdMob घटनाएँ

निम्न तालिका उन घटनाओं को दिखाती है जिनका उपयोग कॉम्बो के साथ किया जा सकता है।

प्रतिस्पर्धा विवरण
onAdLoaded विज्ञापन लोड होने पर कॉल किया जाता है।
onAdFailLoad विज्ञापन लोड होने में विफल होने पर कॉल किया जाता है।
onAdPresent विज्ञापन स्क्रीन पर दिखाए जाने पर कॉल किया जाएगा।
onAdDismiss विज्ञापन खारिज होने पर कॉल किया जाता है।
onAdLeaveApp जब उपयोगकर्ता विज्ञापन पर क्लिक करके ऐप छोड़ता है तो कॉल किया जाता है।

आप नीचे दिए गए उदाहरण का पालन करके इन घटनाओं को संभाल सकते हैं।

document.addEventListener('onAdLoaded', function(e){
   // Handle the event...
});

कॉर्डोवा कैमरा प्लगइन का उपयोग करता है native camera चित्र लेने या छवि गैलरी से चित्र प्राप्त करने के लिए।

कैमरा का उपयोग करना

कमांड प्रॉम्प्ट में अपना प्रोजेक्ट रूट फ़ोल्डर खोलें, फिर कॉर्डोवा कैमरा प्लगइन को निम्न कमांड के साथ डाउनलोड और इंस्टॉल करें।

C:\Users\Username\Desktop\MyApp> cordova plugin add org.apache.cordova.camera

अब, हम एक कैमरा प्लगइन का उपयोग करने के लिए एक सेवा बनाएंगे। हम उपयोग करेंगेAngularJS factory और वादा वस्तु $q कि कारखाने के लिए इंजेक्शन की जरूरत है।

services.js कोड

.factory('Camera', function($q) {
   return {
      getPicture: function(options) {
         var q = $q.defer();

         navigator.camera.getPicture(function(result) {
            q.resolve(result);
         }, function(err) {
            q.reject(err);
         }, options);

         return q.promise;
      }
   }
});

ऐप में इस सेवा का उपयोग करने के लिए, हमें इसे एक निर्भरता के रूप में एक नियंत्रक को इंजेक्ट करने की आवश्यकता है। कॉर्डोवा कैमरा एपीआई प्रदान करता हैgetPicture विधि, जो एक देशी कैमरे का उपयोग करके फ़ोटो लेने के लिए उपयोग की जाती है।

देशी कैमरा सेटिंग्स को इसके द्वारा पारित किया जा सकता है options के लिए पैरामीटर takePictureसमारोह। इस व्यवहार को ट्रिगर करने के लिए उपर्युक्त कोड नमूने को अपने नियंत्रक पर कॉपी करें। यह कैमरा एप्लिकेशन को खोलेगा और एक त्रुटि संदेश के साथ छवि डेटा या त्रुटि कॉलबैक फ़ंक्शन के साथ एक सफलता कॉलबैक फ़ंक्शन लौटाएगा। हमें दो बटनों की भी आवश्यकता होगी जो उन फ़ंक्शन को कॉल करेंगे जिन्हें हम बनाने जा रहे हैं और हमें स्क्रीन पर छवि दिखाने की आवश्यकता है।

HTML कोड

<button class = "button" ng-click = "takePicture()">Take Picture</button>
<button class = "button" ng-click = "getPicture()">Open Gallery</button>
<img ng-src = "{{user.picture}}">

नियंत्रक कोड

.controller('MyCtrl', function($scope, Camera) {
   $scope.takePicture = function (options) { var options = { quality : 75, targetWidth: 200, targetHeight: 200, sourceType: 1 }; Camera.getPicture(options).then(function(imageData) { $scope.picture = imageData;;
      }, function(err) {
         console.log(err);
      });
   };
})

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

यदि आप अपनी गैलरी से छवियों का उपयोग करना चाहते हैं, तो आपको केवल एक चीज को बदलने की आवश्यकता है sourceTypeआपके विकल्प पैरामीटर से विधि। यह परिवर्तन कैमरे के बजाय एक संवाद पॉपअप खोलेगा और आपको डिवाइस से अपनी इच्छित छवि चुनने की अनुमति देगा।

आप निम्न कोड देख सकते हैं, जहां sourceType विकल्प को बदल दिया गया है 0। अब, जब आप दूसरे बटन पर टैप करेंगे, तो यह डिवाइस से फाइल मेन्यू को खोलेगा।

नियंत्रक कोड

.controller('MyCtrl', function($scope, Camera) { $scope.getPicture = function (options) {
	   var options = {
         quality : 75,
         targetWidth: 200,
         targetHeight: 200,
         sourceType: 0
      };

      Camera.getPicture(options).then(function(imageData) {
         $scope.picture = imageData;;
      }, function(err) {
         console.log(err);
      });
   };  
})

आउटपुट निम्न स्क्रीनशॉट में दिखाया गया है।

जब आप अपने द्वारा ली गई छवि को सहेजते हैं, तो यह स्क्रीन पर दिखाई देगा। आप इसे अपनी इच्छानुसार स्टाइल कर सकते हैं।

कई अन्य विकल्पों का भी उपयोग किया जा सकता है, जिनमें से कुछ निम्नलिखित तालिका में दिए गए हैं।

पैरामीटर प्रकार विवरण
गुणवत्ता संख्या छवि की गुणवत्ता, रेंज 0-100
destinationType संख्या छवि का प्रारूप।
स्रोत प्रकार संख्या चित्र के स्रोत को सेट करने के लिए उपयोग किया जाता है।
allowEdit बूलियन छवि के संपादन की अनुमति देने के लिए उपयोग किया जाता है।
encodingType संख्या मान 0 JPEG सेट करेगा, और मान 1 PNG सेट करेगा।
targetWidth संख्या छवि चौड़ाई स्केल करने के लिए उपयोग किया जाता है।
targetHeight संख्या स्केलिंग छवि ऊंचाई के लिए उपयोग किया जाता है।
मीडिया का स्वरूप तार मीडिया प्रकार सेट करने के लिए उपयोग किया जाता है।
cameraDirection संख्या मान 0 बैक कैमरा सेट करेगा, और मान 1 फ्रंट कैमरा सेट करेगा।
popoverOptions तार IOS- केवल विकल्प जो iPad में पॉपओवर स्थान निर्दिष्ट करते हैं।
saveToPhotoAlbum बूलियन छवि को फोटो एलबम में सहेजने के लिए उपयोग किया जाता है।
correctOrientation बूलियन कैप्चर की गई छवियों के ओरिएंटेशन को सही करने के लिए उपयोग किया जाता है।

इस प्लगइन का उपयोग फेसबुक एपीआई से कनेक्ट करने के लिए किया जाता है। इससे पहले कि आप फेसबुक को एकीकृत करना शुरू करें, आपको यहां एक फेसबुक ऐप बनाने की आवश्यकता है । आप एक वेब ऐप बनाएंगे और फिर क्विक स्टार्ट स्क्रीन को छोड़ देंगे। उसके बाद, आपको वेबसाइट प्लेटफ़ॉर्म को इस पर जोड़ना होगाsettingsपृष्ठ। आप विकास के दौरान साइट URL के लिए निम्न कोड स्निपेट का उपयोग कर सकते हैं।

http://localhost:8100/

उसके बाद, आपको जोड़ने की आवश्यकता है Valid OAuth redirect URIs पर settings/advancedपृष्ठ। बस निम्नलिखित दो URL की प्रतिलिपि बनाएँ।

https://www.facebook.com/connect/login_success.html
http://localhost:8100/oauthcallback.html

फेसबुक प्लगइन स्थापित करना

हमने इस प्लगइन का उपयोग करते समय दिखाई देने वाली कुछ समस्याओं से निपटने के लिए उपरोक्त सभी कदम उठाए। इस प्लगइन को स्थापित करना मुश्किल है क्योंकि इसमें बहुत सारे चरण शामिल हैं और प्रलेखन उन सभी को कवर नहीं करता है। अन्य कॉर्डोवा प्लगइन्स के साथ कुछ ज्ञात संगतता समस्याएं भी हैं, इसलिए हम उपयोग करेंगेTeleric verified pluginहमारे app में संस्करण। हम कमांड प्रॉम्प्ट से अपने ऐप में ब्राउज़र प्लेटफ़ॉर्म स्थापित करके शुरू करेंगे।

C:\Users\Username\Desktop\MyApp>ionic platform add browser

अगला, हमें जो करना है वह जोड़ना है root के शीर्ष पर तत्व body टैग करें index.html

index.html

<div id = "fb-root"></div>

अब हम अपने ऐप में कॉर्डोवा फेसबुक प्लगइन जोड़ेंगे। आपको बदलने की जरूरत हैAPP_ID तथा APP_NAME आपके द्वारा पहले बनाए गए फेसबुक ऐप का मिलान करने के लिए।

C:\Users\Username\Desktop\MyApp>cordova -d plugin add 
   https://github.com/Telerik-Verified-Plugins/Facebook/ 
   --variable APP_ID = "123456789" --variable APP_NAME = "FbAppName"

अब खोलो index.html और अपने बाद निम्न कोड जोड़ें bodyटैग। फिर से आपको यह सुनिश्चित करने की आवश्यकता है कि दappId तथा versionआपके द्वारा बनाए गए फेसबुक ऐप का मिलान कर रहे हैं। यह सुनिश्चित करेगा कि फेसबुक एसडीके को बाकी ऐप को ब्लॉक किए बिना एसिंक्रोनस रूप से लोड किया गया है।

index.html

<script>
   window.fbAsyncInit = function() {
      FB.init({
         appId      : '123456789',
         xfbml      : true,
         version    : 'v2.4'
      });
   };

   (function(d, s, id) {
      var js, fjs = d.getElementsByTagName(s)[0];
      if (d.getElementById(id)) {return;}
      js = d.createElement(s); js.id = id;
      js.src = "//connect.facebook.net/en_US/sdk.js";
      fjs.parentNode.insertBefore(js, fjs);
   }(document, 'script', 'facebook-jssdk'));
</script>

कोणीय सेवा

चूंकि हमने सब कुछ स्थापित किया है, हमें सेवा बनाने की आवश्यकता है जो फेसबुक से हमारा कनेक्शन होगा। इन चीजों के अंदर कम कोड के साथ किया जा सकता हैcontroller, लेकिन हम सर्वोत्तम प्रथाओं का पालन करने की कोशिश करते हैं, इसलिए हम कोणीय सेवा का उपयोग करेंगे। निम्नलिखित कोड पूरी सेवा को दर्शाता है। हम इसे बाद में समझाएंगे।

services.js

.service('Auth', function($q, $ionicLoading) { this.getLoginStatus = function() { var defer = $q.defer();
      
      FB.getLoginStatus(function(response) {
		   if (response.status === "connected") {
            console.log(JSON.stringify(response));
         } else {
            console.log("Not logged in");
         }
      });

      return defer.promise;
   }
   this.loginFacebook = function() {
      var defer = $q.defer(); FB.login(function(response) { if (response.status === "connected") { console.log(JSON.stringify(response)); } else { console.log("Not logged in!"); } }); return defer.promise; } this.logoutFacebook = function() { var defer = $q.defer();

      FB.logout(function(response) {
         console.log('You are logged out!');
      });

      return defer.promise;
   }
   this.getFacebookApi = function() {
      var defer = $q.defer();

      FB.api("me/?fields = id,email", [], function(response) {
		
         if (response.error) {
            console.log(JSON.stringify(response.error));
         } else {
            console.log(JSON.stringify(response));
         }
      });

      return defer.promise;
   }
});

उपरोक्त सेवा में, हम चार कार्य बना रहे हैं। पहले तीन स्व-व्याख्यात्मक हैं। चौथे फ़ंक्शन का उपयोग फेसबुक ग्राफ एपीआई से कनेक्ट करने के लिए किया जाता है। यह वापस आ जाएगीid तथा email फेसबुक उपयोगकर्ता से।

हम पैदा कर रहे हैं promise objectsअतुल्यकालिक जावास्क्रिप्ट कार्यों को संभालने के लिए। अब हमें अपने नियंत्रक को लिखना होगा जो उन कार्यों को कॉल करेगा। बेहतर समझ के लिए हम प्रत्येक फ़ंक्शन को अलग से कहेंगे, लेकिन आपको वांछित प्रभाव प्राप्त करने के लिए उनमें से कुछ को एक साथ मिलाना होगा।

नियंत्रक कोड

.controller('MyCtrl', function($scope, Auth, $ionicLoading) { $scope.checkLoginStatus = function() {
      getLoginUserStatus();
   }

   $scope.loginFacebook = function(userData) { loginFacebookUser(); }; $scope.facebookAPI = function() {
      getFacebookUserApi();
   }

   $scope.logoutFacebook = function() {
      logoutFacebookUser();
   };

   function loginFacebookUser() {
      return Auth.loginFacebook();
   }

   function logoutFacebookUser() {
      return Auth.logoutFacebook();
   }

   function getFacebookUserApi() {
      return Auth.getFacebookApi();
   }

   function getLoginUserStatus() {
      return Auth.getLoginStatus();
   }
})

आप शायद सोच रहे हैं कि हम क्यों नहीं लौटे Authफ़ंक्शन अभिव्यक्तियों (पहले चार कार्यों) से सीधे सेवा। इसका कारण यह है कि आप शायद इसके बाद कुछ और व्यवहार जोड़ना चाहेंगेAuthसमारोह वापस आ गया है। आप अपने डेटाबेस में कुछ डेटा भेज सकते हैं, लॉगिन के बाद मार्ग बदल सकते हैं, आदि यह जावास्क्रिप्ट का उपयोग करके आसानी से किया जा सकता हैthen() कॉलबैक के बजाय सभी अतुल्यकालिक संचालन को संभालने की विधि।

अब हमें उपयोगकर्ताओं को ऐप के साथ सहभागिता करने की अनुमति देने की आवश्यकता है। हमारे HTML में हमारे द्वारा बनाए गए चार कार्यों को कॉल करने के लिए चार बटन होंगे।

HTML कोड

<button class = "button" ng-click = "loginFacebook()">LOG IN</button>
<button class = "button" ng-click = "logoutFacebook()">LOG OUT</button>
<button class = "button" ng-click = "checkLoginStatus()">CHECK</button>
<button class = "button" ng-click = "facebookAPI()">API</button>

जब उपयोगकर्ता टैप करता है LOG INबटन, फेसबुक स्क्रीन दिखाई देगा। लॉगिन सफल होने के बाद उपयोगकर्ता को ऐप पर रीडायरेक्ट किया जाएगा।

Cordova InAppBrowser प्लगइन का उपयोग वेब ब्राउज़र दृश्य के अंदर आपके ऐप से बाहरी लिंक खोलने के लिए किया जाता है।

ब्राउज़र का उपयोग करना

इस प्लगइन के साथ काम करना शुरू करना बहुत आसान है। आपको बस कमांड प्रॉम्प्ट विंडो खोलने और कॉर्डोवा प्लगइन स्थापित करने की आवश्यकता है।

C:\Users\Username\Desktop\MyApp>cordova plugin add org.apache.cordova.inappbrowser

यह चरण हमें इसका उपयोग शुरू करने की अनुमति देता है inAppBrowser। अब हम एक बटन बना सकते हैं जो हमें कुछ बाहरी लिंक तक ले जाएगा, और प्लगइन को ट्रिगर करने के लिए एक सरल फ़ंक्शन जोड़ देगा।

HTML कोड

<button class = "button" ng-click = "openBrowser()">OPEN BROWSER</button>

नियंत्रक कोड

.controller('MyCtrl', function($scope, $cordovaInAppBrowser) { var options = { location: 'yes', clearcache: 'yes', toolbar: 'no' }; $scope.openBrowser = function() {
      $cordovaInAppBrowser.open('http://ngcordova.com', '_blank', options)
		
      .then(function(event) {
         // success
      })
		
      .catch(function(event) {
         // error
      });
   }
})

जब उपयोगकर्ता बटन टैप करता है तो InAppBrowser हमारे द्वारा प्रदान किए गए URL को खोल देगा।

इस प्लगइन के साथ कई अन्य तरीकों का इस्तेमाल किया जा सकता है, जिनमें से कुछ निम्न तालिका में हैं।

कॉर्डोवा $ inAppBrowser मेथड

तरीका मापदंडों प्रकार विवरण
setDefaultOptions (parameter1) विकल्प वस्तु सभी InAppBrowsers के लिए वैश्विक विकल्प सेट करने के लिए उपयोग किया जाता है।
खुला (पैरामीटर 1, पैरामीटर 2, पैरामीटर 3) URL, लक्ष्य, विकल्प string, string, object तीन लक्ष्य उपलब्ध हैं। _blank नया inAppBrowser उदाहरण खुलेगा। _system खुलेगा सिस्टम ब्राउज़र और _self वर्तमान ब्राउज़र उदाहरण का उपयोग करेगा।
बंद करे / / InAppBrowser को बंद करने के लिए उपयोग किया जाता है।

कॉर्डोवा इनएपब्रोसर इवेंट्स

यह प्लगइन उन घटनाओं को भी प्रस्तुत करता है जिन्हें साथ जोड़ा जा सकता है $rootScope

उदाहरण विवरण
$ RootScope।$on('$cordovaInAppBrowser: loadstart ', function (e, event)); जब InAppBrowser पृष्ठ लोड करना शुरू करता है, तो कॉल किया जाता है।
$rootScope.$पर ('$ cordovaInAppBrowser: loadstop', function (e, event)); जब InAppBrowser ने पृष्ठ लोड करना समाप्त कर लिया है तो कॉल किया गया।
$ RootScope।$on('$cordovaInAppBrowser: loaderror ', function (e, event)); जब InAppBrowser में त्रुटि आई है, तो कॉल किया गया।
$rootScope.$पर ('$ cordovaInAppBrowser: exit', function (e, event)); InAppBrowser विंडो बंद होने पर कॉल किया जाता है।

इस प्लगइन का उपयोग Ionic ऐप में देशी ऑडियो ध्वनियों को जोड़ने के लिए किया जाता है।

मूल ऑडियो का उपयोग करना

इस प्लगइन का उपयोग करने में सक्षम होने के लिए, हमें पहले इसे स्थापित करने की आवश्यकता है। कमांड प्रॉम्प्ट विंडो खोलें और कॉर्डोवा प्लगइन जोड़ें।

C:\Users\Username\Desktop\MyApp>cordova plugin add cordova-plugin-nativeaudio

इस प्लगइन का उपयोग शुरू करने से पहले हमें ऑडियो फाइल की आवश्यकता होगी। सादगी के लिए, हम अपने को बचाएंगेclick.mp3 अंदर फ़ाइल करें js फ़ोल्डर, लेकिन आप इसे जहाँ चाहें रख सकते हैं।

अगला कदम ऑडियो फाइल को प्रीलोड करना है। दो विकल्प उपलब्ध हैं, जो हैं -

  • preloadSimple - यह सरल ध्वनियों के लिए उपयोग किया जाता है जो एक बार खेला जाएगा।

  • preloadComplex - यह उन ध्वनियों के लिए है जिन्हें लूपिंग ध्वनियों या पृष्ठभूमि ऑडियो के रूप में खेला जाएगा।

ऑडियो फ़ाइल को प्रीलोड करने के लिए अपने कंट्रोलर में निम्न कोड जोड़ें। हमें यह सुनिश्चित करने की आवश्यकता है कि ऑडियो फ़ाइल को प्रीलोड करने से पहले आयोनिक प्लेटफ़ॉर्म लोड हो जाए।

नियंत्रक कोड

$ionicPlatform.ready(function() {
   $cordovaNativeAudio .preloadSimple('click', 'js/click.mp3') .then(function (msg) { console.log(msg); }, function (error) { console.log(error); }); $cordovaNativeAudio.preloadComplex('click', 'js/click.mp3', 1, 1)
	.then(function (msg) {
      console.log(msg);
   }, function (error) {
      console.error(error);
   });
});

उसी नियंत्रक में, हम ऑडियो चलाने के लिए कोड जोड़ेंगे। हमारी$timeout फ़ंक्शन बंद हो जाएगा और पांच सेकंड के बाद लूपिंग ऑडियो को अनलोड करना होगा।

$scope.playAudio = function () {
   $cordovaNativeAudio.play('click'); }; $scope.loopAudio = function () {
   $cordovaNativeAudio.loop('click'); $timeout(function () {
      $cordovaNativeAudio.stop('click'); $cordovaNativeAudio.unload('click');
   }, 5000);
}

आखिरी चीज जो हमें चाहिए वह है ऑडियो चलाने और लूपिंग के लिए बटन बनाना।

HTML कोड

<button class = "button" ng-click = "playAudio()">PLAY</button>

<button class = "button" ng-click = "loopAudio()">LOOP</button>

जब हम play बटन पर टैप करते हैं, तो हम एक बार ध्वनि सुनेंगे और जब हम लूप बटन पर टैप करेंगे, तो ध्वनि पाँच सेकंड के लिए लूप करेगी और फिर रुक जाएगी। यह प्लगइन केवल एमुलेटर या मोबाइल डिवाइस पर काम करता है।

इस प्लगइन का उपयोग आयोनिक ऐप में जियोलोकेशन प्लगइन जोड़ने के लिए किया जाता है।

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

जियोलोकेशन प्लगइन का उपयोग करने का एक सरल तरीका है। हमें इस प्रॉम्प्ट को कमांड प्रॉम्प्ट विंडो से इंस्टॉल करना होगा।

C:\Users\Username\Desktop\MyApp>cordova plugin add cordova-plugin-geolocation

निम्न नियंत्रक कोड दो विधियों का उपयोग कर रहा है। पहला वाला हैgetCurrentPositionविधि और यह हमें उपयोगकर्ता के डिवाइस का वर्तमान अक्षांश और देशांतर दिखाएगा। दूसरा वाला हैwatchCurrentPosition वह विधि जो स्थिति बदलने पर डिवाइस की वर्तमान स्थिति को वापस कर देगी।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $cordovaGeolocation) {
   var posOptions = {timeout: 10000, enableHighAccuracy: false};
   $cordovaGeolocation .getCurrentPosition(posOptions) .then(function (position) { var lat = position.coords.latitude var long = position.coords.longitude console.log(lat + ' ' + long) }, function(err) { console.log(err) }); var watchOptions = {timeout : 3000, enableHighAccuracy: false}; var watch = $cordovaGeolocation.watchPosition(watchOptions);
	
   watch.then(
      null,
		
      function(err) {
         console.log(err)
      },
	   function(position) {
         var lat  = position.coords.latitude
         var long = position.coords.longitude
         console.log(lat + '' + long)
      }
   );

   watch.clearWatch();
})

आपने भी गौर किया होगा posOptions तथा watchOptionsवस्तुओं। हम प्रयोग कर रहे हैंtimeout समय की अधिकतम लंबाई को समायोजित करने के लिए जिसे मिलीसेकेंड में और पास करने की अनुमति है enableHighAccuracyअसत्य पर सेट है। इसे सेट किया जा सकता हैtrueसर्वोत्तम संभव परिणाम प्राप्त करने के लिए, लेकिन कभी-कभी यह कुछ त्रुटियों को जन्म दे सकता है। वहाँ भी है एकmaximumAgeविकल्प जिसका उपयोग यह दिखाने के लिए किया जा सकता है कि पुरानी स्थिति को कैसे स्वीकार किया जाता है। यह मिलीसेकंड का उपयोग कर रहा है, टाइमआउट विकल्प के समान है।

जब हम अपना ऐप शुरू करते हैं और कंसोल खोलते हैं, तो यह डिवाइस के अक्षांश और देशांतर को लॉग करेगा। जब हमारी स्थिति बदल जाती है,lat तथा long मूल्यों में परिवर्तन होगा।

यह प्लगइन हमें एक डिवाइस पर ऑडियो फाइलों को रिकॉर्ड करने और प्लेबैक करने की अनुमति देता है।

मीडिया का उपयोग करना

अन्य सभी कॉर्डोवा प्लगइन्स के साथ, पहली चीज जो हमें करने की ज़रूरत है वह है इसे कमांड प्रॉम्प्ट विंडो से इंस्टॉल करना।

C:\Users\Username\Desktop\MyApp>cordova plugin add cordova-plugin-media

अब, हम प्लगइन का उपयोग करने के लिए तैयार हैं। निम्नलिखित कोड नमूने में,srcस्रोत एमपी 3 फ़ाइल है जिसका उपयोग हम इस ट्यूटोरियल के लिए करेंगे। इसमें रखा गया हैjs फ़ोल्डर, लेकिन हमें जोड़ने की आवश्यकता है /android_asset/www/ इससे पहले, तो यह Android उपकरणों पर इस्तेमाल किया जा सकता है।

पूर्ण कार्यक्षमता के अंदर लपेटा जाता है $ionicPlatform.ready()यह सुनिश्चित करने के लिए फ़ंक्शन कि सब कुछ लोड होने से पहले प्लगइन का उपयोग किया जाता है। उसके बाद, हम बना रहे हैंmedia का उपयोग करके वस्तु newMedia(src)तरीका। media प्ले, पॉज़, स्टॉप और रिलीज़ फ़ंक्शंस जोड़ने के लिए ऑब्जेक्ट का उपयोग किया जाता है।

नियंत्रक कोड

.controller('MyCtrl', function($scope, $ionicPlatform, $cordovaMedia) {
   $ionicPlatform.ready(function() { var src = "/android_asset/www/js/song.mp3"; var media = $cordovaMedia.newMedia(src);

      $scope.playMedia = function() { media.play(); }; $scope.pauseMedia = function() {
         media.pause();
      };

      $scope.stopMedia = function() { media.stop(); }; $scope.$on('destroy', function() {
         media.release();
      });
   });
}

हम प्ले, पॉज़ और स्टॉप फ़ंक्शंस के लिए तीन बटन भी बनाएंगे।

<button class = "button" ng-click = "playMedia()">PLAY</button>

<button class = "button" ng-click = "pauseMedia()">PAUSE</button>

<button class = "button" ng-click = "stopMedia()">STOP</button>

हमें इस प्लगइन को काम करने के लिए किसी एमुलेटर या मोबाइल डिवाइस पर चलाना होगा। जब उपयोगकर्ता प्ले बटन पर टैप करता है, तोsong.mp3 खेलना शुरू कर देंगे।

आप उपरोक्त उदाहरण में देख सकते हैं कि हम क्या उपयोग करते हैं srcएक विकल्प पैरामीटर के रूप में। अन्य वैकल्पिक पैरामीटर हैं जिनका उपयोग किया जा सकता हैnewMedia तरीका।

वैकल्पिक पैरामीटर

निम्न तालिका उपलब्ध सभी वैकल्पिक मापदंडों को दिखाएगी।

पैरामीटर प्रकार विवरण
mediaSuccess समारोह वर्तमान प्ले / रिकॉर्ड या स्टॉप एक्शन के बाद कॉल किया गया।
mediaError समारोह त्रुटि होने पर मंगवाया गया।
mediaStatus समारोह स्थिति परिवर्तन दिखाने के लिए आमंत्रित किया गया।

अगली तालिका उपलब्ध सभी विधियों को दिखाएगी।

उपलब्ध तरीके

निम्न तालिका उपलब्ध सभी विधियों को दिखाएगी।

तरीका मापदंडों विवरण
newMedia (parameter1) src मीडिया वस्तु लौटाता है जिसका उपयोग भविष्य के तरीकों के लिए किया जाएगा। src ऑडियो सामग्री का एक URI है।
getCurrentPosition / एक ऑडियो फ़ाइल के भीतर वर्तमान स्थिति देता है।
getDuration / एक ऑडियो फ़ाइल की अवधि देता है।
खेल / खेल शुरू या फिर से शुरू करने के लिए इस्तेमाल किया।
ठहराव / प्लेबैक को रोकने के लिए उपयोग किया जाता है।
रुकें / खेलना बंद कर देते थे।
रिहाई / ऑडियो संसाधनों को जारी करने के लिए उपयोग किया जाता है।
seekTo (parameter1) मिलीसेकेंड मिलीसेकंड में प्लेबैक स्थिति सेट करने के लिए उपयोग किया जाता है।
setVolume (parameter1) आयतन वॉल्यूम बदलने के लिए उपयोग किया जाता है। रेंज 0 से 1 तक है
startRecord () / रिकॉर्डिंग शुरू करने के लिए उपयोग किया जाता है।
stopRecord / रिकॉर्डिंग बंद करने के लिए उपयोग किया जाता है।

हर मोबाइल ऐप को एक आइकन और स्प्लैश स्क्रीन की आवश्यकता होती है। Ionic इसे जोड़ने के लिए उत्कृष्ट समाधान प्रदान करता है और डेवलपर्स के लिए न्यूनतम कार्य की आवश्यकता होती है। क्रॉपिंग और आकार बदलना Ionic सर्वर पर स्वचालित है।

स्प्लैश स्क्रीन और आइकन जोड़ना

पहले के अध्यायों में, हमने चर्चा की है कि Ionic ऐप के लिए अलग-अलग प्लेटफ़ॉर्म कैसे जोड़े जाएं। एक मंच जोड़कर, Ionic उस मंच के लिए कॉर्डोवा स्प्लैश स्क्रीन प्लगइन स्थापित करेगा ताकि हमें बाद में कुछ भी स्थापित करने की आवश्यकता न हो। हमें केवल दो छवियों को ढूंढना है।

चित्र होने चाहिए png, psd या aiफ़ाइलें। आइकन छवि के लिए न्यूनतम आयाम 192x192 और स्प्लैश स्क्रीन छवि के लिए 2208 × 2208 होना चाहिए। यह आयाम सभी उपकरणों को कवर करेगा। हमारे उदाहरण में, हम दोनों के लिए समान छवि का उपयोग करेंगे। छवियों को सहेजने की आवश्यकता हैresourcesडिफ़ॉल्ट के बजाय फ़ोल्डर। जब हम इसके साथ हो जाते हैं, तो हमें कमांड प्रॉम्प्ट विंडो में निम्नलिखित को चलाने की आवश्यकता होती है।

C:\Users\Username\Desktop\MyApp>ionic resources

अब, अगर आप जाँच करें resources/android या resources/iosफ़ोल्डर, आप देखेंगे कि विभिन्न छवियों के आकार को समायोजित करने के लिए हमने जो चित्र पहले जोड़े थे, उनका आकार बदला और क्रॉप किया गया है। जब हम अपना ऐप डिवाइस पर चलाते हैं, तो ऐप शुरू होने से पहले हमें एक स्प्लैश स्क्रीन दिखाई देगी और हम देखेंगे कि एक डिफ़ॉल्ट Ionic आइकन बदल गया है।

NOTE - यदि आप Android और iOS के लिए अलग-अलग चित्रों का उपयोग करना चाहते हैं, तो आप इसे जोड़ सकते हैं resources/android तथा resources/ios के स्थान पर resources फ़ोल्डर।