स्नेहा टच - क्विक गाइड
Sencha Touch मोबाइल अनुप्रयोगों के लिए उपयोगकर्ता इंटरफ़ेस बनाने के लिए Sencha का एक लोकप्रिय ढांचा है। यह डेवलपर को सरल एचटीएमएल, सीएसएस, जेएस का उपयोग करके एक मोबाइल ऐप बनाने में मदद करता है जो एंड्रॉइड, आईओएस, ब्लैकबेरी और विंडोज जैसे कई मोबाइल उपकरणों का समर्थन करता है। यह MVC आर्किटेक्चर पर आधारित है। स्नेहा टच का नवीनतम संस्करण 2.4 है।
सांचा टच का इतिहास
स्नेचा के अन्य उत्पाद, एक्सटीजे को जारी करने के बाद, जो वेब अनुप्रयोग के लिए था, एक रूपरेखा विकसित करने की आवश्यकता थी जो मोबाइल उपकरणों पर भी काम करती है।
स्नेहा टच का पहला संस्करण 0.9 बीटा संस्करण था, जो एंड्रॉइड और आईओएस उपकरणों का समर्थन करता था। बाद में, स्नेहा टच संस्करण 1.0 की पहली मुख्य रिलीज नवंबर 2010 में हुई, जो पहला स्थिर संस्करण था और ब्लैकबेरी उपकरणों का भी समर्थन किया।
स्नेहा टच की नवीनतम रिलीज़ जून 2015 में जारी किया गया संस्करण 2.4 है, जो कई उपकरणों का समर्थन करता है जैसे कि विंडोज, टाइजन के साथ एंड्रॉइड, आईओएस, ब्लैकबेरी ओएस 10, एंड्रॉइड के लिए Google क्रोम और मोबाइल सफारी, आदि।
स्नेहा टच की विशेषताएं
स्नेहा टच की सबसे प्रमुख विशेषताएं निम्नलिखित हैं -
अनुकूलन और 50 से अधिक यूआई विगेट्स में समृद्ध यूआई जैसे कि सूची, हिंडोला, प्रपत्र, मेनू और टूलबार के संग्रह के साथ निर्मित होते हैं, विशेष रूप से मोबाइल प्लेटफार्मों के लिए निर्मित होते हैं।
पुराने के साथ नए संस्करणों की कोड संगतता।
एक लचीला लेआउट प्रबंधक जो विभिन्न ओएस के साथ कई मोबाइल उपकरणों में डेटा और सामग्री के प्रदर्शन को व्यवस्थित करने में मदद करता है।
ढांचे में एक मजबूत डेटा पैकेज शामिल है जो किसी भी बैकेंड डेटा स्रोत से डेटा का उपभोग कर सकता है।
अनुकूली लेआउट, एनिमेशन, और उपयोग के लिए एक बेहतर मोबाइल वेब एप्लिकेशन अनुभव के लिए चिकनी स्क्रॉलिंग।
आउट-ऑफ-द-बॉक्स, प्रत्येक प्रमुख मंच के लिए देशी-दिखने वाले थीम वेब और हाइब्रिड अनुप्रयोगों को लक्ष्य प्लेटफार्मों के रूप और स्वरूप से मेल खाने में सक्षम बनाता है।
स्नेहा स्पर्श। लाभ
स्नेचा टच बिजनेस-ग्रेड वेब एप्लिकेशन डेवलपमेंट के लिए अग्रणी मानक है। यह विकासशील अनुप्रयोगों के लिए एक मंच प्रदान करने वाले अधिकांश मोबाइल उपकरणों के लिए मजबूत अनुप्रयोगों के निर्माण के लिए आवश्यक उपकरण प्रदान करता है। निम्नलिखित कुछ लाभ हैं -
एक उत्तरदायी स्पर्श सुविधा प्रदान करता है, इसलिए उपयोगकर्ता मोबाइल ऐप का उपयोग करते हुए आसानी से नेविगेट कर सकता है।
आईओएस, एंड्रॉइड और ब्लैकबेरी, और विंडोज के सभी नवीनतम संस्करणों के साथ संगतता प्रदान करता है।
किसी भी मोबाइल एप्लिकेशन के लिए सबसे तेजी से संभव गति प्रदान करता है।
अपने क्रॉस-प्लेटफॉर्म संगतता के साथ एक लागत प्रभावी समाधान प्रदान करता है।
मूल एपीआई और मूल वेब विकास भाषाओं जैसे कि HTML, CSS, JS पर आधारित है, जो एक डेवलपर के लिए स्नेहा टच को समझना आसान बनाता है।
स्नेहा स्पर्श ha सीमाएँ
स्नेहा टच एपीआई में निम्नलिखित क्षमता नहीं है -
ऐप में डिवाइस के कैमरा, कॉन्टैक्ट्स और एक्सेलेरोमीटर तक पहुंच नहीं है।
यह पुश अधिसूचना सुविधा प्रदान नहीं करता है। इसके लिए हमें वेबस्कैट या लंबे मतदान का उपयोग करना होगा।
सामान्य सार्वजनिक लाइसेंस नीति के अनुसार, यह वाणिज्यिक स्रोतों के लिए भुगतान किए गए खुले स्रोत अनुप्रयोगों के लिए मुफ़्त है।
यह हार्डकोर ग्राफिक्स और एनीमेशन ऐप जैसे गेमिंग ऐप्स के लिए अच्छा नहीं है।
स्नेहा स्पर्श। उपकरण
सांचा एस.डी.के.
यह Sencha डेवलपमेंट किट है जिसका इस्तेमाल प्रोजेक्ट का कंकाल बनाने के लिए किया जाता है। हम कमांड में दिए गए नाम के साथ एक ऐप बनाने के लिए कमांड "sencha -sdk पाथ / टू / टच जनर ऐप appName" का उपयोग करते हैं।
जब एप्लिकेशन बनाया जाता है, तो आप ऐप में निम्नलिखित फाइलें देख सकते हैं -
app - इस फोल्डर में ऐप के लिए मॉडल, व्यू, कंट्रोलर और स्टोर फाइल्स हैं।
app.js- यह आपके आवेदन के लिए मुख्य JS फाइल है। इस फ़ाइल से, Sencha कोड प्रवाह शुरू होता है।
app.json - यह एप्लिकेशन के लिए कॉन्फ़िगरेशन फ़ाइल है, सभी कॉन्फ़िगरेशन विवरण यहां प्रस्तुत करते हैं।
index.html - यह मुख्य html फ़ाइल है जहाँ हम app.js और अन्य Sencha संबंधित फ़ाइलों को शामिल करते हैं।
package.json - इस फाइल में एप से जुड़ी सारी निर्भरता और अन्य जानकारियां हैं।
resources - इस फ़ोल्डर में एप्लिकेशन के लिए आवश्यक सभी CSS फाइलें और चित्र शामिल हैं।
सेन्चा सीएमडी
सेन्चा सीएमडी एक कमांड लाइन उपकरण है, जो उत्पादन उद्देश्य के लिए स्नेहा टच कोड मिनिफिकेशन, मचान, बिल्ड जनरेशन और अन्य उपयोगी सुविधाओं की सुविधा प्रदान करता है।
हम इसके लिए एप्लिकेशन बनाने के लिए कमांड प्रॉम्प्ट में कमांड "सेंका ऐप बिल्ड पैकेज" का उपयोग करते हैं। कमांड प्रॉम्प्ट में ऐप डायरेक्टरी पर जाएं और उपरोक्त कमांड टाइप करें। एक बार निर्माण सफल होने के बाद, हम मूल रूप से उत्पादन उद्देश्य के लिए उपयोग किए जाने वाले एप्लिकेशन का छोटा संस्करण देखेंगे।
इससे डाउनलोड किया जा सकता है https://www.sencha.com/products/extjs/cmd-download/
सेन्चा इंस्पेक्टर
Sencha इंस्पेक्टर विकास के दौरान Sencha कोड में किसी भी मुद्दे को डिबग करने के लिए एक डिबगिंग टूल है।
स्थानीय पर्यावरण सेटअप
यह अनुभाग आपको अपनी मशीन पर स्नेहा टच डाउनलोड करने और सेट करने के तरीके के बारे में बताता है। कृपया पर्यावरण स्थापित करने के लिए चरणों का पालन करें।
लाइब्रेरी फ़ाइलों को डाउनलोड करना
निम्नलिखित लिंक से स्नेहा टच लाइब्रेरी फ़ाइलों का व्यावसायिक संस्करण डाउनलोड करें https://www.sencha.com। आपको अपनी पंजीकृत मेल आईडी पर साइट से ट्रायल वर्जन मिलेगा, जो कि एक ज़िप्ड फ़ोल्डर होगा, जिसका नाम sencha-touch-2.4.2-Commercial होगा।
फ़ोल्डर को अनज़िप करें और आपको अपने आवेदन में शामिल करने के लिए विभिन्न जावास्क्रिप्ट और सीएसएस फाइलें मिलेंगी। अधिकतर निम्न फ़ाइलों को शामिल करें -
Javascript Files - JS फाइल जिसे आप फ़ोल्डर के तहत पा सकते हैं \ sencha-touch-2.4.2 व्यावसायिक / टच-2.4.2 हैं -
अनु क्रमांक | फाइल विवरण |
---|---|
1 | sencha-touch.js यह कोर फ़ाइल है जिसमें एप्लिकेशन को चलाने के लिए सभी कार्यक्षमताओं हैं। |
2 | sencha-touch-all.js इस फ़ाइल में फ़ाइल में कोई टिप्पणी नहीं के साथ सभी कोड शामिल हैं। |
3 | sencha-touch-debug.js यह डीबगिंग उद्देश्य के लिए sencha-touch-all.js का निर्विवाद संस्करण है। |
4 | sencha-touch-all-debug.js यह फ़ाइल भी निर्विवाद है और इसका उपयोग विकास के उद्देश्य के लिए किया जाता है क्योंकि इसमें किसी भी त्रुटि / मुद्दों की जांच करने के लिए सभी टिप्पणियाँ और कंसोल लॉग होते हैं। |
आप इन फ़ाइलों को अपने प्रोजेक्ट्स JS फ़ोल्डर में जोड़ सकते हैं या आप एक सीधा रास्ता प्रदान कर सकते हैं जहाँ फ़ाइलें आपके सिस्टम में रहती हैं।
CSS Files - विषय आधारित फ़ाइलों की संख्या है जो आप फ़ोल्डर I के अंतर्गत पा सकते हैं: \ sencha स्पर्श \ sencha-touch-2.4.2-Commercial \ Touch-2.4.2 \ Resources \ css \ sencha-touch.css
ये लाइब्रेरी फाइलें स्नेहा टच एप्लीकेशन में इस प्रकार जोड़ी जाएंगी -
<html>
<head>
<script type = "text/javascript" src = "../sencha-touch-2.4.2-commercial/touch-2.4.2/sencha-touch-all.js"></script>
<link href = "../sencha-touch-2.4.2-commercial/touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type ="text/javascript" src = "app.js" > </script>
</head>
</html>
आप Sencha टच एप्लिकेशन कोड को app.js फ़ाइल में रख सकते हैं।
CDN सेटअप
CDN सामग्री वितरण नेटवर्क है जिसके साथ आपको Sencha टच लाइब्रेरी फ़ाइलों को डाउनलोड करने की आवश्यकता नहीं है, इसके बजाय आप सीधे अपने कार्यक्रम में ExtJS के लिए CDN लिंक जोड़ सकते हैं -
<html>
<head>
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel="stylesheet" />
<script type = "text/javascript" src = "app.js" > </script>
</head>
</html>
लोकप्रिय संपादकों
जैसा कि यह वेब अनुप्रयोगों के विकास के लिए उपयोग किया जाने वाला जावास्क्रिप्ट ढांचा है, इस परियोजना में एचटीएमएल, जेएस फाइलें होंगी, और अपने चरम जेएस कार्यक्रमों को लिखने के लिए, आपको एक पाठ संपादक की आवश्यकता होगी। बाजार में कई आईडीई उपलब्ध हैं। लेकिन अभी के लिए, आप निम्नलिखित में से एक पर विचार कर सकते हैं -
Notepad - विंडोज मशीन पर, आप किसी भी साधारण पाठ संपादक जैसे नोटपैड (इस ट्यूटोरियल के लिए अनुशंसित), नोटपैड ++ का उपयोग कर सकते हैं।
Brackets - एक और लोकप्रिय आईडीई जिसे डाउनलोड किया जा सकता है http://brackets.io/ ।
Sublime - एक और लोकप्रिय आईडीई जिसे डाउनलोड किया जा सकता है https://www.sublimetext.com/3/ ।
Naming conventionपहचानकर्ताओं के लिए नियमों का एक सेट है। यह कोड को अन्य प्रोग्रामर के लिए भी आसानी से पढ़ने योग्य और समझने योग्य बनाता है।
स्नेहा टच में नामकरण सम्मेलन मानक जावास्क्रिप्ट सम्मेलन का अनुसरण करता है, जो अनिवार्य नहीं है लेकिन पालन करने के लिए एक अच्छा अभ्यास है। यह वर्ग, विधि, चर और गुणों के नामकरण के लिए ऊंट मामले के सिंटैक्स का पालन करना चाहिए।
यदि नाम दो शब्दों के साथ संयुक्त है, तो दूसरा शब्द हमेशा एक अपरकेस अक्षर से शुरू होगा। उदाहरण के लिए, doLayout (), StudentForm, FirstName, आदि।
अनु क्रमांक। | नाम और सम्मेलन |
---|---|
1 | Class Name यह एक बड़े अक्षर से शुरू होना चाहिए, उसके बाद ऊंट के मामले में। उदाहरण के लिए, StudentClass |
2 | Method Name यह एक लोअरकेस अक्षर से शुरू होना चाहिए, उसके बाद ऊंट के मामले में। उदाहरण के लिए, छात्रमैथोड () |
3 | Variable Name यह एक लोअरकेस अक्षर से शुरू होना चाहिए, उसके बाद ऊंट के मामले में। उदाहरण के लिए, छात्रनाम |
4 | Constant Name यह केवल अपरकेस में होना चाहिए। उदाहरण के लिए, COUNT, MAX_VALUE |
5 | Property Name यह एक लोअरकेस अक्षर से शुरू होना चाहिए, उसके बाद ऊंट के मामले में। उदाहरण के लिए, enableColumnResize = true |
किसी भी मोबाइल एप्लिकेशन के लिए नीचे की परत OS है, उसके ऊपर कुछ भी या सब कुछ बनाया गया है। फिर हमारे पास ब्राउज़र हैं जिन पर हम एप्लिकेशन चला रहे होंगे। यह क्रोम, सफारी, IE कुछ भी हो सकता है। ऊपरी परत एक डब्ल्यू 3 मानक है, जो सभी के लिए सामान्य है। Sencha Touch खड़ा है या W3 मानकों के शीर्ष पर बनाया गया है, जो HTML5 के अलावा कुछ भी नहीं है, जो विभिन्न उपकरणों के विभिन्न ब्राउज़रों के साथ एक एकल अनुप्रयोग को संगत बनाता है।
सेन्चा टच तीन चौखटों का एक संयोजन है - एक्सटज, जक्कट, और राफेल (वेक्टर ड्राइंग)। यह MVC आर्किटेक्चर का अनुसरण करता है। MVC कोड को अधिक प्रबंधनीय विखंडू में अलग करता है।
यद्यपि कार्यक्रम के लिए वास्तुकला अनिवार्य नहीं है, हालांकि, अपने कोड को अत्यधिक बनाए रखने और व्यवस्थित करने के लिए इस संरचना का पालन करना सबसे अच्छा अभ्यास है।
स्नेहा टच ऐप के साथ प्रोजेक्ट संरचना
----------src
----------resources
-------------------CSS files
-------------------Images
----------JavaScript
--------------------App Folder
-------------------------------Controller
------------------------------------Contoller.js
-------------------------------Model
------------------------------------Model.js
-------------------------------Store
------------------------------------Store.js
-------------------------------View
------------------------------------View.js
-------------------------------Utils
------------------------------------Utils.js
--------------------------------app.js
-----------HTML files
स्नेहा टच ऐप फ़ोल्डर आपके प्रोजेक्ट के जावास्क्रिप्ट फ़ोल्डर में रहेगा।
अनुप्रयोग में नियंत्रक, दृश्य, मॉडल, स्टोर और उपयोगिता फ़ाइलें होंगी।
app.js- मुख्य फाइल जहां से प्रोग्राम का प्रवाह शुरू होगा। इसे <script> टैग का उपयोग करके मुख्य HTML फ़ाइल में शामिल किया जाना चाहिए। ऐप बाकी की कार्यक्षमता के लिए एप्लिकेशन के नियंत्रक को कॉल करता है।
Controller.js- यह स्नेचा टच एमवीसी आर्किटेक्चर की कंट्रोलर फाइल है। इसमें एप्लिकेशन, ईवेंट श्रोताओं और कोड की अधिकांश कार्यक्षमता का सभी नियंत्रण शामिल है। यह निम्नलिखित कार्य करता है: दृश्य और मॉडल के बीच रूटिंग, इंटरमीडिएट और घटनाओं को निष्पादित करता है।
View.js- इसमें एप्लिकेशन का इंटरफ़ेस हिस्सा है, जो उपयोगकर्ता को दिखाता है। स्नेहा टच विभिन्न यूआई समृद्ध विचारों का उपयोग करता है, जिन्हें आवश्यकता के अनुसार बढ़ाया और अनुकूलित किया जा सकता है।
Store.js- इसमें स्थानीय रूप से कैश्ड डेटा होता है, जिसे मॉडल ऑब्जेक्ट की मदद से दृश्य पर प्रदान किया जाना है। स्टोर प्रॉक्सिस का उपयोग करके डेटा प्राप्त करता है, जिसमें बैकेंड डेटा को लाने के लिए सेवाओं के लिए परिभाषित पथ है।
Model.js- इसमें वे ऑब्जेक्ट्स होते हैं जो देखने के लिए स्टोर डेटा को बांधते हैं। यह वास्तविक दुनिया की वस्तु का प्रतिनिधित्व है, जो मूल रूप से डेटाबेस से संबंधित है।
Utils.js- यह MVC आर्किटेक्चर में शामिल नहीं है, लेकिन कोड को साफ, कम जटिल, और अधिक पढ़ने योग्य बनाने के लिए इसका उपयोग करना सबसे अच्छा अभ्यास है। हम इस फ़ाइल में विधियाँ लिख सकते हैं और जहाँ भी आवश्यकता हो, उन्हें कंट्रोलर या व्यू रेंडरर में बुला सकते हैं। यह कोड पुन: प्रयोज्य उद्देश्य के लिए भी सहायक है।
एमवीसी मॉडल व्यू कंट्रोलर के लिए है। यह एक वास्तुशिल्प पैटर्न है जो एप्लिकेशन को तार्किक घटकों में अलग करता है और इसे अधिक प्रबंधनीय बनाता है।
निम्नलिखित आरेख से पता चलता है कि MVC वास्तुकला कैसे काम करती है -
Controller - नियंत्रक पूरे आवेदन को नियंत्रित करता है यह देखें कि क्या मॉडल बदला गया है और उपयोगकर्ता इनपुट के आधार पर कार्रवाई करता है।
View- इसमें एप्लिकेशन का इंटरफ़ेस हिस्सा है जो उपयोगकर्ता के लिए दृश्य है। यह उपयोगकर्ता इनपुट पर मॉडल को बदलने के लिए नियंत्रक को सूचित करता है।
Model- इसमें वे ऑब्जेक्ट्स होते हैं जो देखने के लिए स्टोर डेटा को बांधते हैं। यह वास्तविक विश्व वस्तु का प्रतिनिधित्व करता है जो मूल रूप से डेटाबेस से संबंधित है। यह देखने में किसी भी परिवर्तन के लिए नियंत्रक को सूचित करता है।
इस अध्याय में, हम एक्सटी जेएस में पहला हैलो वर्ल्ड प्रोग्राम लिखने के चरणों को सूचीबद्ध करेंगे।
चरण 1
हमारी पसंद के संपादक में एक index.htm पेज बनाएँ। HTML पेज के हेड सेक्शन में आवश्यक लाइब्रेरी फाइल्स को इस प्रकार शामिल करें।
index.htm
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js">
</script>
<script type = "text/javascript">
Ext.application( {
name: 'Sencha', launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true, items: [{
title: 'Home', iconCls: 'home', html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
<body>
</body>
</html>
व्याख्या
Ext.application () विधि Sencha Touch एप्लिकेशन का प्रारंभिक बिंदु है। यह एक ग्लोबल वैरिएबल बनाता है, जिसे 'Sencha' नाम दिया गया है, जिसे प्रॉपर्टी के नाम के साथ घोषित किया गया है - इसके मॉडल, व्यू और कंट्रोलर जैसे सभी एप्लिकेशन की कक्षाएं इस सिंगल नेमस्पेस के तहत रहेंगी, जिससे ग्लोबल वैरिएबल और फाइल के नाम से टकराने की संभावना कम हो जाती है।
पेज तैयार होने के बाद लॉन्च () विधि को कहा जाता है और सभी जावास्क्रिप्ट फाइलें लोड होती हैं।
Sencha टच में ऑब्जेक्ट बनाने के लिए Ext.create () विधि का उपयोग किया जाता है। यहां, हम साधारण पैनल क्लास Ext.tab.Panel का ऑब्जेक्ट बना रहे हैं।
Ext.tab.Panel एक पैनल बनाने के लिए स्नेहा टच में पूर्वनिर्धारित वर्ग है।
हर Sencha Touch वर्ग में कुछ बुनियादी कार्य करने के लिए अलग-अलग गुण होते हैं।
Ext.Panel वर्ग में विभिन्न गुण होते हैं जैसे -
fullscreen संपत्ति एक पूर्ण स्क्रीन का उपयोग करना है, इसलिए पैनल फुलस्क्रीन स्थान लेगा।
items संपत्ति विभिन्न मदों के लिए कंटेनर है।
iconCls विभिन्न आइकन प्रदर्शित करने के लिए उपयोग की जाने वाली कक्षा है।
title संपत्ति पैनल को शीर्षक प्रदान करना है।
html संपत्ति HTML सामग्री है जिसे पैनल में दिखाया जाना है।
चरण 2
एक मानक ब्राउज़र में index.htm फ़ाइल खोलें और आपको निम्न आउटपुट मिलेगा।
एक वेब एप्लिकेशन की आज की मांग कम विकास प्रयासों के साथ एक तेजी से एप्लिकेशन विकसित करना है। स्नेहा टच आसानी के साथ ऐसा करने में मदद करता है क्योंकि यह कस्टम बिल्ड बनाने की सुविधा के साथ विकास या उत्पादन कोड के आधार पर कई बिल्ड लाइब्रेरी चुनने के लिए प्रदान करता है।
स्नेहा टच बिल्ड लाइब्रेरीज़ गतिशील रूप से कक्षाओं को लोड करती हैं। डायनामिक लोडिंग उन वर्गों के लिए है जो आवश्यकता होने पर लोड हो जाते हैं और केवल उन्हीं वर्गों को शामिल किया जाएगा जो आवेदन में आवश्यक हैं। यह एप्लिकेशन को तेज़ी से चलाता है क्योंकि लोड की जाने वाली फ़ाइलों की संख्या कम हो जाती है, साथ ही लोड करने का समय भी कम हो जाता है।
स्नेहा टच 2.x निम्नलिखित पांच बिल्ड लाइब्रेरी प्रदान करता है।
अनु क्रमांक। | बनाता है और उपयोग |
---|---|
1 | sencha-touchdebug.js स्थानीय स्तर पर एप्लिकेशन को विकसित करते समय इस बिल्ड का उपयोग किया जाता है। यह विकास के दौरान आसान डिबगिंग के लिए सभी टिप्पणियों और डिबग लॉग के साथ एक गैर-सूचीबद्ध संस्करण है। |
2 | senchatouch.js इस फ़ाइल का उपयोग उत्पादन के उद्देश्य के लिए किया जाता है। जब हम एक कस्टम बिल्ड करते हैं तो यह छोटा संस्करण होता है। |
3 | sencha-touchall.js इस फ़ाइल का उपयोग उत्पादन के उद्देश्य के लिए किया जाता है। यह कस्टमाइज्ड वर्जन है जब हमारे पास कस्टम बिल्ड नहीं है। |
4 | sencha-touchall-debug.js इस फ़ाइल का उपयोग उत्पादन में डीबगिंग के लिए किया जाता है। यह छोटा नहीं है और इसमें सभी टिप्पणियां और डिबग लॉग हैं। |
5 | sencha-touchall-compat.js इस बिल्ड का उपयोग संस्करण 1.x से संस्करण 2.x पर माइग्रेट करने के लिए किया जाता है। यह एक चेतावनी देता है जहाँ भी संस्करण १.x कोड संगत नहीं है और कोड संशोधन की आवश्यकता है। |
उपर्युक्त बिल्ड के साथ, स्नेहा टच कस्टम बिल्ड बनाने के लिए एक सुविधा प्रदान करता है।
एक कस्टम बिल्ड होने के लाभ
कस्टम बिल्ड सभी स्पर्श फ़ाइलों को लोड नहीं करता है। यह केवल उन फाइलों को लोड करता है, जिनका हम एप्लिकेशन में उपयोग कर रहे हैं, जो एप्लिकेशन को तेज और आसानी से बनाए रखने योग्य बनाता है।
Sencha CMD का उपयोग कस्टम बिल्ड बनाने के लिए किया जाता है। सेन्चा सीएमडी में एक कस्टम बिल्ड बनाने के लिए, उस डायरेक्टरी पर जाएं जहां ऐप फाइल रहती है और बिल्ड बनाने के लिए निम्न कमांड में से एक टाइप करें।
अनु क्रमांक। | कमांड और उपयोग |
---|---|
1 | sencha app build native ऐप बनाता है और packager.temp.json नामक एक फाइल तैयार करता है जिसका उपयोग आप किसी एप्लिकेशन को पैकेज करने के लिए कर सकते हैं - packager.temp.json packager.json के समान है, लेकिन इसमें अतिरिक्त पथ हैं। |
2 | sencha app build -run native बनाता है और स्वचालित रूप से अनुप्रयोग पैकेज करता है, और उपयुक्त सिम्युलेटर लॉन्च करता है। |
3 | sencha app build package पैकेजिंग समर्थन के साथ एप्लिकेशन बनाता है, लेकिन एक पैकेज JSON फ़ाइल को कॉन्फ़िगर नहीं करता है। यह उन प्रोजेक्ट्स के लिए उपयोगी है जो मैन्युअल रूप से कई packager.json फ़ाइलों को बनाए रखते हैं। |
एक बार निर्माण सफल होने के बाद, यह ऑल-क्लासेस.जेएस फ़ाइल उत्पन्न करेगा, जिसे हमें अपने index.html में शामिल करना होगा ताकि इसे तैयार किया जा सके।
निम्न कोड उत्पादन तैयार कोड के लिए किए जाने वाले परिवर्तनों को दर्शाता है।
Index.html before building application
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-debug.js"></script>
<script type = "text/javascript" src = "app.js"> </script>
</head>
<body>
</body>
</html>
Index.html after building the application
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch.js"></script>
<script type = "text/javascript" src = "app.js"> </script>
<script type = "text/javascript" src = "app-classes.js"> </script>
</head>
<body>
</body>
</html>
सेन्चा टच पहले के संस्करण से विभिन्न सुधारों के साथ आता है।
स्नेहा टच 2 पिछड़े संगतता निर्माण के साथ आता है, जो कि माइग्रेशन प्रक्रिया को संस्करण 1.x से 2.x तक आसान बनाता है।
यह बिल्ड केवल चेतावनी और लॉग्स प्रदान करके कार्य को आसान बनाता है जब भी कोई माइग्रेशन समस्या होती है या कोड परिवर्तन की आवश्यकता होती है, तो उपयोगकर्ता को यह पता चल जाएगा कि परिवर्तन कहां हैं, यह सुनिश्चित करने के लिए कि एप्लिकेशन नवीनतम संस्करण के साथ काम करता है।
स्नेहा टच 2.x माइग्रेशन के लिए निम्नलिखित कोड परिवर्तनों की आवश्यकता होती है।
कक्षा प्रणाली
Code in Sencha Touch 1.x -
MyApp.view.StudentPanel = Ext.extend(Ext.Panel, {
scroll: 'vertical',
html: 'Student Panel'
initComponent: function() {
Ext.getCmp('StudentIdDiv').update('This is a Student panel');
}
});
Code in Sencha Touch 2.x -
Ext.define('MyApp.view.StudentPanel', {
extend: 'Ext.Panel',
config: {
scroll: 'vertical',
html: 'Student Panel'
},
initialize: function() {
Ext.getCmp('StudentIdDiv').setHtml('This is a Student panel')
}
});
दोनों संस्करणों को देखकर, आप कक्षा बनाने का तरीका देख सकते हैं, यह परिवर्तन है जो अब ExtJs से प्रेरित है जैसे कि -
Ext.extend को Ext.define में बदल दिया जाता है।
वर्ग से संबंधित सभी कॉन्फ़िगरेशन पैरामीटर अब कॉन्फ़िगरेशन पैरामीटर के तहत परिभाषित किए गए हैं।
InitComponent को इनिशियलाइज़ () विधि में बदल दिया जाता है।
Sencha Touch 2.x में, हम html को अपडेट करने या मान प्राप्त करने के लिए setHtml () और getHtml () फ़ंक्शन कर सकते हैं।
MVC आर्किटेक्चर
स्नेहा टच 1.x कोड मॉड्यूलर था और MVC आर्किटेक्चर पर आधारित था। मॉडल, दृश्य और नियंत्रक लिखने के लिए स्नेहा टच 2.x एक अलग वाक्यविन्यास का अनुसरण करता है। आइए विभिन्न संस्करणों में मॉडल, दृश्य और नियंत्रक फ़ाइलों का अंतर देखें।
नमूना
Code in Sencha Touch 1.x -
Ext.regModel('MyApp.model.StudentModel', {
fields: [
{name: 'name', type: 'string'},
{name: 'age', type: 'int'}
]
});
Code in Sencha Touch 2.x -
Ext.define('MyApp.model.StudentModel', {
extend: 'Ext.data.Model', config: {
fields: [
{name: 'name', type: 'string'},
{name: 'age', type: 'int'}
]
}
});
Ext.regModel को Ext.define में बदल दिया जाता है जो Ext.data.Model का विस्तार करता है।
सभी क्षेत्र अब 2.x संस्करण में कॉन्फ़िगर अनुभाग के अंतर्गत आते हैं।
राय
Code in Sencha Touch 1.x -
Ext.Panel("studentView", {
items: [{}]
});
Code in Sencha Touch 2.x -
Ext.define('MyApp.view.StudentView', {
extend: 'Ext.tab.Panel',
items: [{}]
});
दृश्य लगभग समान है, केवल दृश्य नाम होने के नाते केवल परिवर्तन 2.x संस्करण नामस्थान जैसे Myapp.view.StudentView और कोड मॉडल की तरह Ext.define विधि में लिख रहा है।
नियंत्रक
Code in Sencha Touch 1.x -
Ext.regController("studentController", {
someMethod: function() {
alert('Method is called');
}
});
Code in Sencha Touch 2.x -
Ext.define('MyApp.controller.studentController', {
extend: 'Ext.app.Controller', someMethod: function() {
alert('Method is called');
}
});
नियंत्रक में मॉडल के रूप में भी। इसके अलावा Ext.regController को Ext.define में बदल दिया जाता है, जो Ext.app.Controller का विस्तार करता है।
आवेदन
Code in Sencha Touch 1.x -
Ext.application({
name: 'MyApp',
launch: function() {
Ext.create('MyApp.view.StudentView');
}
});
Code in Sencha Touch 2.x -
Ext.application({
name: 'MyApp',
models: ['studentModel'],
controllers: ['studentController'],
views: ['studentView'],
stores: ['studentStore'],
launch: function() {
Ext.create('MyApp.view.Main');
}
});
संस्करण 1.x और संस्करण 2.x के बीच का मुख्य अंतर है, 2.x में हम सभी मॉडल, विचार, नियंत्रक और स्टोर को एप्लिकेशन में ही घोषित करते हैं।
स्नेहा टच की विभिन्न मुख्य अवधारणाएँ हैं जैसे कि क्लास सिस्टम, अजाक्स, कंट्रोलर इत्यादि।
निम्नलिखित तालिका Sencha टच की मुख्य अवधारणाओं की लिंक को सूचीबद्ध करती है।
अनु क्रमांक। | अवधारणा और विवरण लिंक |
---|---|
1 | कक्षा प्रणाली |
2 | अवयव |
3 | नियंत्रकों |
4 | ब्लैकबेरी का समर्थन |
5 | अजाक्स का उपयोग |
स्नेहा टच में डेटा पैकेज किसी भी तरह के डेटा हेरफेर को पूरा करने या डेटा को लोड करने के लिए जिम्मेदार है।
डेटा पैकेज मॉडल, स्टोर और प्रॉक्सी से संबंधित हैं।
अनु क्रमांक। | अवधारणा और विवरण लिंक |
---|---|
1 | Model यह डेटा और फ़ील्ड्स का संग्रह है जिसके साथ हम UI पर सभी मान प्रदर्शित करते हैं। विवरण |
2 | Store यह मॉडल उदाहरणों का एक संग्रह है जो मूल रूप से डेटा को स्थानीय रूप से संग्रहीत करता है। स्टोर में हम सभी घटनाओं को लिखते हैं और डेटा प्राप्त करने के लिए बाकी कॉल करते हैं। विवरण |
3 | Proxy यह स्टोर में डेटा लोड करने के लिए मूल रूप से जिम्मेदार है। अधिकतर हम ajax प्रॉक्सी का उपयोग स्टोर डेटा लोड करने के लिए करते हैं। विवरण |
स्नेहा टच आपके अनुप्रयोगों में उपयोग किए जाने वाले कई थीम प्रदान करता है। आप क्लासिक थीम के स्थान पर विभिन्न थीम जोड़ सकते हैं और उस डिवाइस के आधार पर आउटपुट में अंतर देख सकते हैं जो हम एप्लिकेशन के लिए उपयोग कर रहे हैं। यह केवल उदाहरण के रूप में समझाया गया है, सीएसएस फ़ाइल थीम को प्रतिस्थापित करके किया जाता है।
डेस्कटॉप थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। एप्लिकेशन से निम्नलिखित सीएसएस का उपयोग डेस्कटॉप थीम के लिए किया जाता है।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type="text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
विंडोज थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। आवेदन से निम्नलिखित सीएसएस निकालें -
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
विंडोज विषय का उपयोग करने के लिए निम्नलिखित सीएसएस जोड़ें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/wp.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/wp.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
आईओएस थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। आवेदन से निम्नलिखित सीएसएस निकालें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
विंडोज विषय का उपयोग करने के लिए निम्नलिखित सीएसएस जोड़ें
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
आईओएस क्लासिक थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। आवेदन से निम्नलिखित सीएसएस निकालें -
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
Windows विषय का उपयोग करने के लिए निम्नलिखित सीएसएस जोड़ें -
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino-classic.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/cupertino-classic.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
Android थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। आवेदन से निम्नलिखित सीएसएस निकालें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
विंडोज विषय का उपयोग करने के लिए निम्नलिखित सीएसएस जोड़ें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/mountainview.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/mountainview.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
ब्लैकबेरी थीम
अपने पहले हैलो वर्ल्ड एप्लिकेशन पर विचार करें। आवेदन से निम्नलिखित सीएसएस निकालें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css
विंडोज विषय का उपयोग करने के लिए निम्नलिखित सीएसएस जोड़ें।
https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/bb10.css
प्रभाव देखने के लिए, निम्नलिखित कार्यक्रम आज़माएं -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/bb10.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
Ext.create("Ext.tab.Panel", {
fullscreen: true,
items: [{
title: 'Home',
iconCls: 'home',
html: 'Welcome to sencha touch'
}]
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
आज की प्रौद्योगिकियों की दुनिया में, हमारे पास कई डिवाइस हैं जैसे कि मोबाइल, टैबलेट, डेस्कटॉप और लैपटॉप विभिन्न स्क्रीन आकारों के साथ। इसलिए, ऐसे अनुप्रयोगों को विकसित करने की आवश्यकता है, जो सभी उपकरणों से अच्छे रूप और अनुभव के साथ सुलभ हों। हालांकि, विभिन्न उपकरणों के लिए अलग कोड विकसित करने के लिए बहुत समय लगता है और महंगा है।
Sencha टच डिवाइस प्रोफाइल फीचर की पेशकश करके इस संबंध में हमारी मदद करता है। सक्रिय प्रोफ़ाइल के आधार पर, अलग-अलग निर्भरताएं चलेंगी और लागू होंगी।
हम एप्लिकेशन कोड लिखते समय डिवाइस प्रोफाइल की घोषणा कर सकते हैं। हमारे पास कई उपकरण हो सकते हैं जैसे -
Ext.application({
name: 'MyApp',
profiles: ['Phone', 'Tablet']
});
एक बार यह पूरा हो जाने के बाद, प्रोफाइल लोड किया जाएगा -
- MyApp.profiles.Phone.js
- MyApp.profiles.Tablet.js
एक साधारण फोन प्रोफ़ाइल लेखन
Ext.define('Mail.profile.Phone', {
extend: 'Ext.app.Profile',
config: {
name: 'Phone',
views: ['phoneView']
},
isActive: function() {
return Ext.os.is('Phone');
}
});
एक साधारण टैबलेट प्रोफाइल लिखना
Ext.define('Mail.profile.Tablet', {
extend: 'Ext.app.Profile',
config: {
name: 'Tablet',
views: ['tableView']
},
isActive: function() {
return Ext.os.is('Tablet');
}
});
जैसा कि हम प्रोफ़ाइल में देख सकते हैं, हमारे पास निष्क्रिय कार्य है जो निर्धारित करता है कि क्या विशेष उपकरण सक्रिय है। यदि उपकरण सक्रिय है, तो संबंधित निर्भरता लोड और त्वरित होगी।
जैसा कि ऊपर दिए गए उदाहरण में बताया गया है कि यदि हम फोन डिवाइस का उपयोग कर रहे हैं तो फोन प्रोफाइल का आइसेक्टिव फ़ंक्शन सही हो जाएगा और फोन डिवाइस से संबंधित निर्भरताएं लोड हो जाएंगी; यहाँ phoneView लोड किया जाएगा। यदि डिवाइस एक टैबलेट है, तो फोन प्रोफाइल का आइसेटिव फ़ंक्शन झूठा और टैबलेट प्रोफाइल का आइसेक्टिव फ़ंक्शन वापस आ जाएगा और निर्भरता टैबलेट दृश्य लोड हो जाएगा।
लॉन्च प्रक्रिया
यहाँ ध्यान देने वाली एक और बात यह है कि जब हमारे पास आवेदन में प्रोफाइल है, तो आवेदन कोड का लोडिंग और इंस्टेंटेशन निम्नलिखित में होगा -
- नियंत्रकों को पहले त्वरित किया जाता है और प्रत्येक नियंत्रक इनिट फ़ंक्शन को लोड किया जाएगा।
- प्रोफ़ाइल का लॉन्च फ़ंक्शन कहा जाएगा।
- एप्लिकेशन का लॉन्च फ़ंक्शन कहा जाएगा।
प्रोफ़ाइल और एप्लिकेशन के लॉन्च फ़ंक्शन दोनों वैकल्पिक हैं, इसलिए यदि हम उनमें से किसी एक को परिभाषित नहीं करते हैं तो उन्हें कॉल नहीं किया जाएगा।
निम्नलिखित कोड पर एक नज़र डालें कि अलग-अलग लॉन्च और इनिट फ़ंक्शन को कहाँ और कैसे परिभाषित किया जा सकता है।
नियंत्रक init फ़ंक्शन
Ext.define('MyApp.controller.Main', {
extend: 'Ext.app.Controller',
init : function (){
Ext.Msg.alert('Controller's init method');
},
config: {
refs: {
tab: '#divId
}
}
});
प्रोफाइल का लॉन्च समारोह
Ext.define('Mail.profile.Tablet', {
extend: 'Ext.app.Profile',
config: {
name: 'Tablet', views: ['tableView']
},
isActive: function() {
return Ext.os.is('Tablet');
}
launch : function() {
Ext.Msg.alert('profile's launch function');
}
});
एप्लिकेशन का लॉन्च फ़ंक्शन
Ext.application({
name: 'Sencha', launch: function() {
Ext.Msg.alert(Application's launch function);
}
});
Sencha Touch में निर्भरता घोषित करने के कुछ तरीके दिए गए हैं, एक आवेदन के भीतर और दूसरा वर्गों के अंदर।
आइए निर्भरता को परिभाषित करने के विभिन्न तरीकों पर एक नज़र डालें।
आवेदन स्तर निर्भरता
यहाँ, हम सभी निर्भरताएँ घोषित करते हैं जब हम Ext.application बनाते हैं।
Ext.application({
name: 'MyApp',
views: ['StudentsView'],
models: ['StudentsModel'],
controllers: ['StudentsController'],
stores: ['StudentsStore'],
profiles: ['Phone', 'Tablet']
});
अब, जब एप्लिकेशन लोड हो जाता है, तो सभी निर्भरताएं एक ही समय में लोड हो जाएंगी। अन्य फ़ाइलों का पथ होगा -
- MyApp.views.StudentsView
- MyApp.models.StudentsModel
- MyApp.stores.StudentsStore आदि।
घोषणा का उपरोक्त तरीका न केवल फ़ाइल को लोड करता है, बल्कि यह भी तय करता है कि इसे किस प्रोफाइल को सक्रिय रखना चाहिए। कंट्रोलर को लोड करने के बाद, यह तुरंत सुनिश्चित करता है। एक बार स्टोर लोड हो जाने के बाद, यह उन्हें तुरंत चालू करता है और यदि पहले से नहीं दिया गया है तो एक आईडी प्रदान करता है।
प्रोफ़ाइल-विशिष्ट निर्भरताएँ
जब हम किसी एप्लिकेशन में प्रोफाइल का उपयोग कर रहे हैं, तो संभावनाएं हो सकती हैं कि कुछ विशिष्ट प्रोफाइल के लिए केवल कुछ कार्यक्षमताएं आवश्यक हैं।
प्रोफाइल विशिष्ट निर्भरताएं आवेदन स्तर की घोषणा के बजाय प्रोफाइल में ही घोषित की जाती हैं।
Ext.define('MyApp.profile.Tablet', {
extend: 'Ext.app.Profile', config: {
views: ['StudentView'], controllers: ['StudentController'], models: ['StudentModel']
}
});
निर्भरताएँ प्रोफ़ाइल के सक्रिय होने या न होने के बावजूद लोड हो जाती हैं। हालाँकि, सक्रिय प्रोफ़ाइल के आधार पर, आगे की प्रक्रिया जैसे कि इंस्टेंटिंग कंट्रोलर और स्टोर होते हैं।
नेस्ट डिपेंडेंसीज
जब हमारे पास बड़ा आवेदन होता है तो हमारे पास कई नियंत्रक, मॉडल, विचार और स्टोर होते हैं।
बड़े अनुप्रयोगों में मॉड्यूलरिटी रखना हमेशा अच्छा होता है। उसके लिए, हम सबफ़ोल्डर्स को परिभाषित कर सकते हैं और निर्भरता की घोषणा करते समय हम घोषित करने के लिए सबफ़ोल्डर नाम का उपयोग कर सकते हैं।
Ext.application({
name: 'MyApp',
controllers: ['Controller', 'nested.NewController'],
views: ['class.Cview', 'SView']
});
उपरोक्त मामले में, निम्नलिखित फाइलें भरी जाएंगी -
- MyApp.controllers.Controller
- MyApp.controllers.nested.NewController
- MyApp.Views.Sview
- MyApp.Views.class.Cview
बाहरी निर्भरता
हम कक्षाओं के पूरी तरह से योग्य नाम देकर आवेदन के बाहर निर्भरता को निर्दिष्ट कर सकते हैं -
Ext.Loader.setPath({
'Class': 'Class'
});
Ext.application({
views: ['Class.view.LoginForm', 'Welcome'],
controllers: ['Class.controller.Sessions', 'Main'],
models: ['Class.model.User']
});
उपरोक्त मामले में, निम्नलिखित फाइलें भरी जाएंगी -
- Class/view/LoginForm.js
- Class/controller/Sessions.js
- Class/model/User.js
- app/view/Welcome.js
- app/controller/Main.js
यह आपको पहचानने में मदद करता है कि आप किस ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं, आप किस ब्राउज़र पर काम कर रहे हैं और आपके पर्यावरण के लिए कौन-कौन सी सुविधाएँ उपलब्ध हैं।
स्नेहा टच पर्यावरण के लिए विशिष्ट जानकारी प्राप्त करने के लिए विभिन्न कार्य प्रदान करता है। नीचे बताए गए सभी तरीकों को जांचा जा सकता है, अगर हालत है (Ext.os.is.Windows) {} है और शर्त के आधार पर कार्य किया जा सकता है।
निम्नलिखित सभी विधियाँ बूलियन मान लौटाती हैं।
ऑपरेटिंग सिस्टम
Ext.os एक ऐसा वर्ग है जो आपको यह जानने के लिए अलग-अलग तरीके देता है कि हम किस ऑपरेटिंग सिस्टम पर काम कर रहे हैं।
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.os.is.webOS यदि आप वेबोस ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
2 | Ext.os.is.RIMTable यदि आप RIMTable ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
3 | Ext.os.is.Linux यदि आप लिनक्स ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
4 | Ext.os.is.Windows यदि आप विंडोज़ ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
5 | Ext.os.is.MacOs यदि आप मैक ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही हो जाएगा अन्यथा यह गलत हो जाता है। |
6 | Ext.os.is.BlackBerry यदि आप BlackBerry ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
7 | Ext.os.is.iOS यदि आप IOS ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
8 | Ext.os.is.Android यदि आप एंड्रॉइड ऑपरेटिंग सिस्टम का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आएगा अन्यथा यह गलत है। |
डिवाइस का पता लगाना
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.os.is.iPad यदि आप iPad का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आ जाएगा और यह गलत है। |
2 | Ext.os.is.iPhone यदि आप iPhone का उपयोग कर रहे हैं तो यह फ़ंक्शन सही हो जाएगा अन्यथा यह गलत है। |
3 | Ext.os.is.iPod यदि आप iPod का उपयोग कर रहे हैं तो यह फ़ंक्शन सही वापस आ जाएगा और यह गलत है। |
ऑपरेटिंग सिस्टम का संस्करण
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.os.name यह ऑपरेटिंग सिस्टम का नाम देता है। |
2 | Ext.os.version.version यह ऑपरेटिंग सिस्टम का संस्करण देता है जिसका हम उपयोग कर रहे हैं। |
ब्राउज़र का पता लगाना
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.browser.is.IE यदि हम इंटरनेट एक्सप्लोरर ब्राउज़र का उपयोग कर रहे हैं तो यह फ़ंक्शन सही है, अन्यथा यह गलत है। |
2 | Ext.browser.is.FF यदि हम फ़ायर्फ़ॉक्स ब्राउज़र का उपयोग कर रहे हैं तो यह फ़ंक्शन सही है, अन्यथा यह गलत है। |
3 | Ext.browser.is.Chrome यदि हम क्रोम ब्राउज़र का उपयोग कर रहे हैं तो यह फ़ंक्शन सही है अन्यथा यह गलत है। |
4 | Ext.browser.is.Opera यदि हम ओपेरा ब्राउज़र का उपयोग कर रहे हैं तो यह फ़ंक्शन सही है अन्यथा यह गलत है। |
5 | Ext.browser.is.Safari यदि हम सफारी ब्राउज़र का उपयोग कर रहे हैं तो यह फ़ंक्शन सही है, अन्यथा यह गलत है। |
यह कार्य Ext.browser विभिन्न अन्य कार्य प्रदान करता है -
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.browser.userAgent यह वर्तमान userAgent को लौटाता है। |
2 | Ext.browser.isSecure यदि वर्तमान पृष्ठ SSL का उपयोग कर रहा है तो यह सही है। |
3 | Ext.browser.isStrict यदि ब्राउज़र सख्त मोड में है तो यह सही है। |
4 | Ext.browser.engineName यह ब्राउज़र इंजन नाम (WebKit, Gecko, Presto, Trident and Other) लौटाता है। |
5 | Ext.browser.engineVersion यह ब्राउज़र इंजन का संस्करण लौटाता है। |
विशेषताएं
Ext.feature.has यह देखना है कि ब्राउज़र में निम्नलिखित फ़ीचर हैं या नहीं।
अनु क्रमांक | विधि और विवरण |
---|---|
1 | Ext.feature.has.Audio यदि ब्राउज़र HTML5 की ऑडियो टैग सुविधा का समर्थन करता है तो यह विधि सही है। |
2 | Ext.feature.has.Canvas यदि ब्राउज़र HTML5 की कैनवास टैग सुविधा का समर्थन करता है तो यह विधि सही है। |
3 | Ext.feature.has.classList यदि ब्राउज़र HTML5 के क्लास लिस्ट फीचर का उपयोग करता है, जो html एलिमेंट के लिए css क्लासेस को जोड़ने, हटाने और टॉगल करने के लिए उपयोग किया जाता है, तो यह विधि सही साबित होती है। |
4 | Ext.feature.has.Css3dTransforms यदि ब्राउज़र css3 के Css 3D ट्रांसफ़ॉर्म फ़ीचर को सपोर्ट करता है तो यह तरीका सही है। |
5 | Ext.feature.has.CssAnimations यदि ब्राउज़र css3 के एनिमेशन का समर्थन करता है तो यह तरीका सही है। |
6 | Ext.feature.has.CssTransforms यदि ब्राउजर css3 के Css ट्रांसफ़ॉर्म फ़ीचर को सपोर्ट करता है तो यह तरीका सही है। |
7 | Ext.feature.has.CssTransitions यदि ब्राउज़र css3 के संक्रमण सुविधा का समर्थन करता है तो यह विधि सही है। |
8 | Ext.feature.has.DeviceMotion यदि ब्राउजर डिवाइस मोशन फीचर को सपोर्ट करता है तो यह तरीका सही है। |
9 | Ext.feature.has.Geolocation यदि ब्राउज़र HTML5 की जियोलोकेशन सुविधा का समर्थन करता है तो यह विधि सही है। |
10 | Ext.feature.has.History यदि ब्राउज़र HTML की इतिहास सुविधा का समर्थन करता है तो यह विधि सही है। |
1 1 | Ext.feature.has.Orientation यह विधि सही हो जाती है यदि ब्राउज़र यह पता लगा सकता है कि कौन सा उपकरण अभिविन्यास |
12 | Ext.feature.has.OrientationChange यदि ब्राउज़र डिवाइस के ओरिएंटेशन में परिवर्तन का पता लगा सकता है तो यह विधि सही है। |
13 | Ext.feature.has.Range रेंज, स्लाइडर स्लाइडर रेंज के लिए HTML इनपुट टैग का एक प्रकार है इसलिए यदि ब्राउज़र स्लाइडर का समर्थन करता है तो यह फ़ंक्शन सही होता है। |
14 | Ext.feature.has.SqlDatabase वेब एसक्यूएल डेटाबेस डेटा एन डेटाबेस को संग्रहीत करने के लिए एक वेब पेज एपीआई है जिस पर हम क्वेरी ऑपरेशन कर सकते हैं। यदि ब्राउज़र वेब Sql डेटाबेस का समर्थन करता है तो यह विधि सही है। |
15 | Ext.feature.has.Svg Svg स्केलेबल वेक्टर ग्राफिक्स के लिए खड़ा है, अगर ब्राउज़र html 5 के svg फीचर को सपोर्ट करता है तो यह तरीका सही है। |
16 | Ext.feature.has.Touch यदि ब्राउजर में टच फीचर है तो यह तरीका सही है। |
17 | Ext.feature.has.Video यदि ब्राउज़र html 5 वीडियो टैग का समर्थन करता है तो यह विधि सही है। |
18 | Ext.feature.has.Vml Vml वेक्टर मार्कअप लैंग्वेज के लिए है जो xml आधारित मार्कअप लैंग्वेज है। यदि ब्राउज़र ने vml का समर्थन किया है तो यह विधि सही है। |
19 | Ext.feature.has.WebSockets वेब सॉकेट मूल रूप से कंप्यूटर के लिए एक संचार प्रोटोकॉल है जो क्लाइंट और सर्वर के बीच दो संचार का समर्थन करता है। यदि ब्राउज़र वेबसॉफ़्ट का समर्थन करता है तो यह विधि सही हो जाती है अन्यथा यह गलत हो जाता है। |
घटनाएँ कुछ ऐसी होती हैं जो कक्षा में कुछ होने पर निकाल दी जाती हैं। उदाहरण के लिए, जब एक बटन क्लिक किया जा रहा है या एक तत्व प्रदान करने से पहले / उसके बाद।
लेखन घटनाओं के तरीके
घटनाओं को लिखने के तरीके निम्नलिखित हैं।
- श्रोताओं का उपयोग करके अंतर्निहित ईवेंट।
- घटनाओं को बाद में संलग्न करना
- कस्टम ईवेंट
श्रोताओं का उपयोग करके निर्मित ईवेंट
स्नेहा टच फाइलों में घटनाओं और कस्टम घटनाओं को लिखने के लिए श्रोता टच श्रोता संपत्ति प्रदान करता है।
स्नेहा टच में श्रोता
हम पिछले कार्यक्रम में श्रोता को पैनल में सुनने की संपत्ति जोड़कर, निम्नानुसार दिखाएंगे -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha', launch: function() {
Ext.create('Ext.Panel', {
html: 'My Panel', fullscreen: true, listeners: {
painted: function() {
Ext.Msg.alert('I was painted to the screen');
}
}
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम देगा -
इस तरह हम श्रोताओं की संपत्ति में कई घटनाओं को भी लिख सकते हैं।
एक ही श्रोता में कई घटनाएँ
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
var myButton = Ext.Viewport.add({
xtype: 'button',
centered: true,
text: 'Click me'
});
myButton.on({
tap: function() {
var randomWidth = 100 + Math.round(Math.random() * 200);
this.setWidth(randomWidth);
},
widthchange: function(button, newWidth, oldWidth) {
alert('My width changed from ' + oldWidth + ' to ' + newWidth);
}
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
बाद में घटना को अंजाम देना
घटनाओं को लिखने की पिछली विधि में, हमने तत्वों को बनाने के समय श्रोताओं में घटनाओं को लिखा है।
घटनाओं को संलग्न करने का दूसरा तरीका इस प्रकार है -
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
var myButton = Ext.Viewport.add({
xtype: 'button',
centered: true,
text: 'Click me'
});
myButton.on('tap', function() {
alert("Event listener attached by .on");
});
}
});
</script>
</head>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
कस्टम ईवेंट
हम स्नेहा टच में कस्टम ईवेंट लिख सकते हैं और ईवेंट को फायरवेंट विधि से फायर कर सकते हैं। निम्नलिखित उदाहरण बताते हैं कि कैसे कस्टम घटनाओं को लिखना है।
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.application({
name: 'Sencha',
launch: function() {
var myButton = Ext.Viewport.add({
xtype: 'button',
centered: true,
text: "Just wait 5 seconds",
listeners: {
myEvent: function(button, points) {
alert('myEvent was fired! You score ' + points + ' points');
}
}
});
Ext.defer(function() {
var number = Math.ceil(Math.random() * 100);
myButton.fireEvent('myEvent', myButton, number);
}, 5000);
}
});
</script>
</head>
</html>
एक बार जब पृष्ठ लोड हो जाता है और दस्तावेज़ तैयार हो जाता है, तो बटन के साथ UI पृष्ठ दिखाई देगा और जैसा कि हम 5 सेकंड के बाद किसी घटना को निकाल रहे हैं, दस्तावेज तैयार होने के बाद अलर्ट बॉक्स 5 सेकंड के बाद दिखाई देगा।
यहां हमने कस्टम इवेंट 'मायवेंट' लिखा है और हम ईवेंट्स को बटन के रूप में फायर कर रहे हैं।
लेआउट एक तरह से तत्व एक कंटेनर में व्यवस्थित होते हैं। यह क्षैतिज, ऊर्ध्वाधर या कोई अन्य हो सकता है। Sencha Touch की लाइब्रेरी में अलग-अलग लेआउट परिभाषित हैं, हालांकि हम हमेशा कस्टम लेआउट भी लिख सकते हैं।
अनु क्रमांक। | लेआउट और विवरण |
---|---|
1 | hBox यह लेआउट तत्व को क्षैतिज तरीके से वितरित करने की अनुमति देता है। |
2 | vbox यह लेआउट तत्व को ऊर्ध्वाधर तरीके से वितरित करने की अनुमति देता है। यह आमतौर पर उपयोग किए जाने वाले लेआउट में से एक है। |
3 | फ़िट इस लेआउट में, कंटेनर एकल पैनल से भरा होता है और जब लेआउट से संबंधित कोई विशिष्ट आवश्यकता नहीं होती है, तो इस लेआउट का उपयोग किया जाता है। |
4 | कार्ड (TabPanel) यह लेआउट टैब फैशन में विभिन्न घटकों की व्यवस्था करता है। कंटेनर के शीर्ष पर टैब प्रदर्शित किए जाएंगे। हर बार केवल एक टैब दिखाई देता है और प्रत्येक टैब को एक अलग घटक माना जाता है। |
स्नेहा टच पूर्ण इतिहास समर्थन और गहरी लिंकिंग सुविधाओं के साथ आता है।
इसमें सबसे सरल बैक बटन कार्यक्षमता है, जो उपयोगकर्ता को स्क्रीन के बीच नेविगेट करने में मदद करती है, वह भी पेज या एप्लिकेशन को रिफ्रेश किए बिना।
यह रूट कार्यक्षमता भी प्रदान करता है, जो उपयोगकर्ता को किसी भी URL पर नेविगेट करने में मदद करता है। ब्राउज़र विंडो में दिए गए URL के आधार पर, यह किसी विशिष्ट कार्य को करने के लिए विशिष्ट कार्यों को कहता है।
बैक बटन कार्यक्षमता के लिए निम्न उदाहरण देखें।
यह उदाहरण नेस्टेड सूची को दर्शाता है जो किसी सूची के अंदर एक सूची के अलावा और कुछ नहीं है, इसलिए जब आप किसी सूची आइटम पर क्लिक करते हैं, तो यह एक और सूची खोलता है और स्क्रीन के ऊपर एक बैक बटन दिखाई देता है।
पूर्ण कोड आधार के लिए, आप देख सकते हैं दृश्य घटक अनुभाग के अंतर्गत नेस्टेड सूची ।
मार्ग
मार्गों का सरलतम उदाहरण
Ext.define('MyApp.controller.Main', {
extend: 'Ext.app.Controller',
config: {
routes: {
login: 'showLogin',
'user/:id': 'userId'
}
},
showLogin: function() {
Ext.Msg.alert('This is the login page');
},
userId: function(id) {
Ext.Msg.alert('This is the login page specific to the used Id provided');
}
});
उपरोक्त उदाहरण में यदि ब्राउज़र URL https://myApp.com/#login है तो फ़ंक्शन showLogin कहा जाएगा।
हम URL में पैरामीटर प्रदान कर सकते हैं और विशिष्ट पैरामीटर के आधार पर फ़ंक्शन को बुलाया जा सकता है। उदाहरण के लिए यदि URL https://myApp.com/#user/3 है तो दूसरे फ़ंक्शन userId को कॉल किया जाएगा और फ़ंक्शन के अंदर विशिष्ट ID का उपयोग किया जा सकता है।
अग्रिम मार्ग
कुछ समय के लिए हमारे पास अग्रिम पैरामीटर हैं, जिसमें अल्पविराम, रिक्त स्थान और विशेष वर्ण आदि शामिल हैं यदि हम लेखन मार्गों के उपरोक्त तरीके का उपयोग करते हैं तो यह काम नहीं करेगा। इस समस्या को हल करने के लिए स्नेचा टच सशर्त मार्ग प्रदान करता है जहां हम यह निर्दिष्ट कर सकते हैं कि पैरामीटर को किस प्रकार का डेटा स्वीकार करना चाहिए।
Ext.define('MyApp.controller.Main', {
extend: 'Ext.app.Controller', config: {
routes: {
login/:id: {
action: showLogin, conditions: {':id: "[0-9a-zA-Z\.]+" }
}
},
showLogin: function() {
Ext.Msg.alert('This is the login page with specific id which matches criteria');
}
}
});
इसलिए जैसा कि ऊपर दिए गए उदाहरण में हमने regex को उस स्थिति में दिया है जिसमें स्पष्ट रूप से कहा गया है कि URL पैरामीटर के रूप में किस प्रकार के डेटा को अनुमति दी जानी चाहिए।
विभिन्न डिवाइस प्रोफाइल में एक ही URL साझा करना
चूंकि स्नेचा टच डिवाइस प्रोफाइल प्रदान करता है, इसलिए एक ही एप्लिकेशन कोड का उपयोग कई डिवाइसों में किया जा सकता है, ऐसी संभावनाएं हो सकती हैं कि एक ही URL के लिए अलग-अलग प्रोफाइल में अलग-अलग कार्यक्षमता हो।
इस मुद्दे को हल करने के लिए स्नेचा टच हमें मुख्य नियंत्रक में रूटिंग लिखने की स्वतंत्रता देता है और सभी प्रोफ़ाइल में उनके प्रोफाइल विशिष्ट लोगों के साथ लिखे जाने वाले फ़ंक्शन को कहा जाता है।
Ext.define('MyApp.controller.Main', {
extend: 'Ext.app.Controller', config: {
routes: {
login: 'showLogin'
}
},
});
// For phone profile
Ext.define('MyApp.controller.phone.Main, {
extend: 'MyApp.controller.Main, showLogin: function() {
Ext.Msg.alert('This is the login page for mobile phone profile');
}
});
// For tablet profile
Ext.define('MyApp.controller.tablet.Main, {
extend: 'MyApp.controller.Main,showLogin: function() {
Ext.Msg.alert('This is the login page for tablet profile');
}
});
उदाहरण के रूप में पता चलता है कि हमारे पास एक मुख्य नियंत्रक है जिसमें शोलाइनिन फ़ंक्शन है और हमारे पास दो अलग-अलग प्रोफ़ाइल (फोन / टैबलेट) हैं। दोनों प्रोफ़ाइल में अलग-अलग कोड के साथ शो लोजिन फ़ंक्शन है जो प्रोफ़ाइल के लिए विशिष्ट है।
इस तरह हम एक ही URL को कई विशिष्ट उपकरणों के साथ उनकी विशिष्ट कार्यक्षमता के साथ साझा कर सकते हैं।
स्नेहा टच अजाक्स और अजाक्स 2 विकास के साथ काम करने के लिए एक्सएचआर 2 कॉन्फ़िगरेशन प्रदान करता है।
XHR2 xmlHttpRequest स्तर 2 है, जो सर्वर से डेटा का अनुरोध करने के लिए उपयोग किया जाता है। किसी भी वेब एप्लिकेशन के लिए, डेटा सर्वर पर रहता है और पेज लोड होने के बाद, डेटा को Ajax अनुरोधों की मदद से सर्वर से एक्सेस किया जाना चाहिए।
Sencha टच में XHR2 प्रगति बार सुविधा प्रदान करता है, जो उपयोगकर्ता को किसी विशेष अनुरोध के लिए हस्तांतरित डेटा की मात्रा दिखाता है। XHR2 नया जोड़ा गया है, इसलिए हमें यह जांचने की आवश्यकता है कि ब्राउज़र इसका समर्थन करता है या नहीं।
यह जाँचने के लिए फ़ंक्शन है कि क्या ब्राउज़र XHR2 का समर्थन करता है -
if (Ext.feature.has.XHR2) {
// Here we can write functionality to work if browser supports XHR2
}
हम यह भी जांच सकते हैं कि XHR2 के साथ प्रगतिशील अपलोड ब्राउज़र द्वारा समर्थित है या नहीं।
if (Ext.feature.has.XHRUploadProgress) {
// Here we can write functionality to work if browser supports progressive uploads
}
Sencha Touch में विभिन्न नए XHR2 फीचर शामिल किए गए हैं।
अनु क्रमांक | सुविधाएँ और विवरण |
---|---|
1 | XHR2: true यह अनुप्रयोग में XHR2 कार्यक्षमता को सक्षम और अक्षम करने के लिए उपयोग किया जाता है। |
2 | Ext.field.File नए फ़ाइल फ़ील्ड को फ़ील्ड के प्रकार के बारे में और अधिक जानकारी देने के लिए जोड़ा जाता है। |
3 | Ext.field.FileInput यह FileInput प्रदान करने के लिए। |
4 | Ext.progressIndicator यह प्रगति बार के संदर्भ में हस्तांतरित डेटा का सटीक प्रतिशत प्रदान करना है। |
5 | xtype: fileinput FileInput वर्ग का उदाहरण बनाने के लिए। |
6 | xtype: filefield फ़ाइल वर्ग का उदाहरण बनाने के लिए। |
7 | responseType : value यह पैरामीटर पाठ, दस्तावेज़, बूँद आदि के रूप में विभिन्न प्रकार की प्रतिक्रियाओं की अनुमति देता है। |
पैरामीटर और बिना पैरामीटर के सरल अजाक्स अनुरोध भेजने के लिए निम्नलिखित उदाहरण हैं और अजाक्स का उपयोग करके फाइलें अपलोड करना।
मापदंडों के बिना सरल अजाक्स अनुरोध - सफलता
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.setup({
requires: [ 'Ext.Panel', 'Ext.Button', 'Ext.form.Panel'], onReady: function() {
var request = {
url: 'https://www.tutorialspoint.com/sencha_touch/index.htm',
method: 'POST',
xhr2: true,
success: function(response) {
Ext.Msg.alert('Ajax call successful');
},
failure: function(response) {
Ext.Msg.alert('Ajax call failed');
}
};
Ext.Viewport.add({
xtype:"panel",
layout:"vbox",
fullscreen:true,
items: [
{
xtype:"button",
text: "Ajax",
ui: 'confirm',
handler: function(){
Ext.Ajax.request(request);
}
}
]
});
}
});
</script>
</head>
<body>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
उपरोक्त उदाहरण सफलता ajax कॉल दिखाता है जैसा कि उल्लेख किया गया URL सही है। इस उदाहरण में, हम किसी भी पैरामीटर को पारित नहीं कर रहे हैं, यह सिर्फ एक सरल अजाक्स अनुरोध है जो उल्लिखित URL को हिट करता है।
यदि आप डेवलपर टूल में क्रोम ब्राउज़र का उपयोग कर रहे हैं, तो नेटवर्क अनुभाग पर नेविगेट करें, आप अनुरोध भेज सकते हैं और जो प्रतिक्रिया हमें मिल रही है।
मापदंडों के बिना सरल अजाक्स अनुरोध - विफलता
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.setup({
requires: [
'Ext.Panel',
'Ext.Button',
'Ext.form.Panel'
],
onReady: function() {
var request = {
url: 'https://www.tutorialspoint.com/sencha_touch/indexx.htm',
method: 'POST',
xhr2: true,
success: function(response) {
Ext.Msg.alert('Ajax call successful');
},
failure: function(response) {
Ext.Msg.alert('Ajax call failed');
}
};
Ext.Viewport.add({
xtype:"panel",
layout:"vbox",
fullscreen:true,
items: [
{
xtype:"button",
text: "Ajax",
ui: 'confirm',
handler: function(){
Ext.Ajax.request(request);
}
}
]
});
}
});
</script>
</head>
<body>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
उपरोक्त उदाहरण में, यह दिखाने के लिए कि अजाक्स विफलता कैसे काम करती है, हमने गलत URL का उल्लेख किया है। इस और पिछले उदाहरण की तुलना करें, आपको अंतर मिलेगा।
अजाक्स अनुरोध में पैरामीटर भेजना
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.setup({
requires: [
'Ext.Panel',
'Ext.Button',
'Ext.form.Panel'
],
onReady: function() {
var formData = new FormData();
formData.append("firstName", "Hi");
formData.append("lastName", "Reader");
// Request will be sent as part of the payload instead of standard post data
var request = {
url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
method: 'POST',
xhr2: true,
data: formData,
success: function(response) {
var out = Ext.getCmp("output");
response = Ext.JSON.decode(response.responseText, true);
Ext.Msg.alert(response.message);
},
failure: function(response) {
var out = Ext.getCmp("output");
Ext.Msg.alert('Ajax failed!');
}
};
Ext.Viewport.add({
xtype:"panel",
layout:"vbox",
fullscreen:true,
items: [
{
xtype:"button",
text: "Ajax",
ui: 'confirm',
handler: function(){
Ext.Ajax.request(request);
}
}
]
});
}
});
</script>
</head>
<body>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
इस उदाहरण में, हम अजाक्स कॉल की डेटा संपत्ति का उपयोग करके अजाक्स के साथ पैरामीटर पारित कर रहे हैं।
Ajax का उपयोग करके फ़ाइलें अपलोड करना
<!DOCTYPE html>
<html>
<head>
<link href = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/resources/css/sencha-touch.css" rel = "stylesheet" />
<script type = "text/javascript" src = "https://cdn.sencha.com/touch/sencha-touch-2.4.2/sencha-touch-all.js"></script>
<script type = "text/javascript">
Ext.setup({
requires: [
'Ext.Panel',
'Ext.MessageBox',
'Ext.Button',
'Ext.ProgressIndicator',
'Ext.form.Panel',
'Ext.field.FileInput'
],
onReady: function() {
var progressIndicator = Ext.create("Ext.ProgressIndicator", {
loadingText: "Uploading: {percent}%"
});
var request = {
url: 'https://www.tutorialspoint.com/sencha_touch/sencha_json.php',
method: 'POST',
xhr2: true,
progress:progressIndicator,
success: function(response) {
Ext.Msg.alert('File uploaded successfully.');
},
failure: function(response) {
Ext.Msg.alert('File upload failed.');
}
};
Ext.Viewport.add(progressIndicator);
Ext.Viewport.add({
xtype:"panel",
layout:"vbox",
fullscreen:true,
items: [
{
xtype:"fileinput",
accept:"image/jpeg"
},
{
xtype:"button",
text: "Upload",
ui: 'confirm',
handler: function(){
var input = Ext.Viewport.down("fileinput").input;
var files = input.dom.files;
if (files.length) {
request.binaryData = files[0];
Ext.Ajax.request(request);
}else {
Ext.Msg.alert("Please Select a JPG");
}
}
}
]
});
}
});
</script>
</head>
<body>
</body>
</html>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
यह उदाहरण दिखाता है कि ajax कॉल का उपयोग करके डेटा कैसे अपलोड किया जाए। इस उदाहरण में, हम फ़ाइल को अपलोड करते समय प्रगति दिखाने के लिए प्रगति बार संकेतक का उपयोग कर रहे हैं।
स्नेहा टच विभिन्न यूआई घटक प्रदान करता है, जिसे आवश्यकताओं के अनुसार अनुकूलित किया जा सकता है।
Sr.N0। | घटक विवरण |
---|---|
1 | हिंडोला इस UI घटक का उपयोग हिंडोला प्रदर्शित करने के लिए किया जाता है। |
2 | सूची इस UI घटक का उपयोग सूचियों को प्रदर्शित करने के लिए किया जाता है। |
3 | नेस्टेड सूची यह UI घटक नेस्टेड सूची प्रदर्शित करने के लिए उपयोग किया जाता है। |
4 | प्रपत्र इस UI घटक का उपयोग फ़ॉर्म प्रदर्शित करने के लिए किया जाता है। |
5 | चार्ट इस UI घटक का उपयोग विभिन्न प्रकार के चार्ट प्रदर्शित करने के लिए किया जाता है। |
6 | फ्लोटिंग कंपोनेंट इस यूआई घटक का उपयोग फ्लोटिंग घटक को प्रदर्शित करने के लिए किया जाता है। |
7 | टैब पैनल टैब पैनल दृश्य प्रदर्शित करने के लिए इस UI घटक का उपयोग किया जाता है। |
8 | नेविगेशन दृश्य यह UI घटक नेविगेशन दृश्य प्रदर्शित करने के लिए उपयोग किया जाता है। |
9 | क्रिया मेनू यह यूआई घटक एक्शन मेनू बार प्रदर्शित करने के लिए उपयोग किया जाता है। |
10 | आँकड़ों का खाका इस UI घटक का उपयोग डेटा दृश्य प्रदर्शित करने के लिए किया जाता है। |
1 1 | नक्शा इस UI घटक का उपयोग Google मानचित्र प्रदर्शित करने के लिए किया जाता है। |
स्नेहा टच देशी पैकेजिंग सुविधाओं के साथ आता है।
स्नेहा टच की देशी पैकेजिंग अवधारणाओं के लिए लिंक निम्नलिखित हैं।
अनु क्रमांक। | अवधारणा और विवरण लिंक |
---|---|
1 | देशी iOS प्रावधान |
2 | मूल निवासी एपीआई |
बेसिक जावास्क्रिप्ट सबसे अच्छा अभ्यास
सभी जावास्क्रिप्ट-संबंधित कोड को एक अलग में रखना एक अच्छा अभ्यास है js (external JS) फ़ाइल, इसे लिखने के बजाय <script> दस्तावेज़ निकाय में हेड सेक्शन या इनलाइन जावास्क्रिप्ट के तहत टैग।
तत्व को आगे तर्क में उपयोग करने से पहले हमेशा एक अशक्त जांच करें।
हमेशा नामकरण सम्मेलन का पालन करें, क्योंकि यह किसी अन्य प्रोग्रामर द्वारा कोड को समझना आसान बनाता है।
कोड को आसानी से समझने के लिए, जेएस विधियों के लिए स्पष्ट तर्क के साथ टिप्पणियों को लिखने के लिए हमेशा प्राथमिकता दी जाती है कि एक फ़ंक्शन क्या करता है।
स्नेहा टच के लिए सबसे अच्छा अभ्यास
Sencha Touch Recommended फ़ोल्डर संरचना का उपयोग करें, जो JS कम्प्रेशन या मिनिफिकेशन के दौरान सहायक होगी।
नियंत्रक में श्रोता (onclick / onblur, आदि) का उपयोग करने के बजाय इसे html पृष्ठ में ही लिखने की अत्यधिक अनुशंसा की जाती है।
जब स्टोर को दृश्य से बुलाया जा रहा हो, तो स्टोर का उदाहरण न बनाएं।
जब हम एक स्टोर का एक उदाहरण बनाते हैं, तो हमें हमेशा इसे नष्ट करना चाहिए, क्योंकि यह प्रदर्शन को प्रभावित करता है।
स्नेहा टच का उपयोग करते समय, किसी अन्य सरल जावास्क्रिप्ट फ़ाइल को निर्दिष्ट न करें। एक्सट्रीम कक्षाओं (नियंत्रक या बर्तनों में उल्लिखित) से सभी कार्यों का उपयोग करें।
जब मॉडल मैपिंग और नाम समान हों, तो मैपिंग निर्दिष्ट न करें। केवल नाम उद्देश्य को हल करेगा।
देखने में अनावश्यक गुणों का उपयोग न करें। केवल उसी संपत्ति का उपयोग करें जिसकी आवश्यकता है और यह मान जो डिफ़ॉल्ट मान से अलग है।