Ext.js - प्रश्न और उत्तर
एक्सटेंडेड विस्तारित जावास्क्रिप्ट के लिए जेएस का अर्थ है यह समृद्ध यूआई वेब आधारित डेस्कटॉप अनुप्रयोगों को विकसित करने के लिए एक जावास्क्रिप्ट ढांचा है।
यह एक सेन्चा उत्पाद है जिसे वाईयूआई (याहू यूजर इंटरफेस) से बढ़ाया गया है।
ये एक्सट्रीम JS कोड चलाने के लिए HTML पेज में शामिल होने वाली मुख्य फाइलें हैं -
- Ext-all.js
- Ext-all.css
- अनुकूलन यूआई विगेट्स समृद्ध यूआई जैसे ग्रिड, पिवट ग्रिड, फॉर्म, चार्ट, पेड़ों के संग्रह के साथ।
- पुराने के साथ नए संस्करणों की कोड संगतता।
- एक लचीला लेआउट प्रबंधक कई ब्राउज़रों, उपकरणों और स्क्रीन आकार में डेटा और सामग्री के प्रदर्शन को व्यवस्थित करने में मदद करता है।
- एडवांस डेटा पैकेज डेटा लेयर से UI विजेट्स को डिकम्पोज करता है। डेटा पैकेज अत्यधिक कार्यात्मक मॉडल का उपयोग करके डेटा के क्लाइंट-साइड संग्रह की अनुमति देता है जो सॉर्टिंग और फ़िल्टरिंग जैसी सुविधाओं को सक्षम करता है।
- यह प्रोटोकॉल अज्ञेयवादी है, और किसी भी बैक-एंड स्रोत से डेटा तक पहुंच सकता है।
- अनुकूलन थीम्स एक्सट्रीम जेएस विजेट कई आउट-ऑफ-द-बॉक्स थीम में उपलब्ध हैं जो प्लेटफार्मों भर में सुसंगत हैं।
आधुनिक और विरासत ब्राउज़र दोनों के लिए - डेस्कटॉप, टैबलेट, और स्मार्टफ़ोन में क्रॉस-प्लेटफ़ॉर्म विकास को स्ट्रीमलाइन करता है।
आईडीई प्लगइन्स के माध्यम से उद्यम विकास के वातावरण में एकीकृत करके विकास टीमों की उत्पादकता बढ़ाता है।
वेब अनुप्रयोग विकास की लागत को कम करता है।
एक आकर्षक उपयोगकर्ता अनुभव के साथ एप्लिकेशन बनाने के लिए टीमों को सशक्त बनाता है।
इसमें UI शक्तिशाली और आसान बनाने के लिए विजेट्स का सेट है।
यह MVC आर्किटेक्चर का अनुसरण करता है, इसलिए यह बहुत ही पठनीय कोड है।
लाइब्रेरी का आकार लगभग 500 KB है जो प्रारंभिक लोडिंग समय को अधिक बनाता है और अनुप्रयोग को धीमा बनाता है।
HTML <DIV> टैग्स से भरा है, यह जटिल और डीबग करना मुश्किल बनाता है।
सामान्य सार्वजनिक लाइसेंस नीति के अनुसार यह मुक्त स्रोत अनुप्रयोगों के लिए मुफ़्त है लेकिन वाणिज्यिक अनुप्रयोगों के लिए भुगतान किया जाता है।
सरल चीजों को लोड करने के लिए कुछ समय कोडिंग की कुछ पंक्तियों की आवश्यकता होती है जो सादे html या जेकरी में सरल होती है।
एक्सट जेएस अनुप्रयोगों के विकास के लिए काफी अनुभवी डेवलपर की आवश्यकता है।
Ext JS क्रॉस ब्राउज़र संगतता का समर्थन करता है, यह सभी प्रमुख ब्राउज़रों का समर्थन करता है -
- IE 6 और ऊपर
- फ़ायरफ़ॉक्स 3.6 और ऊपर
- Chrome10 और इसके बाद के संस्करण
- सफारी 4 और इसके बाद के संस्करण
- ओपेरा 11 और ऊपर
Ext JS 4+ MVC (मॉडल व्यू कंट्रोलर) आर्किटेक्चर का समर्थन करता है। Ext JS 5 से इसने MVVM (मॉडल व्यू व्यूमॉडल) को भी सपोर्ट करना शुरू कर दिया।
Ext JS 6, Ext JS का नवीनतम संस्करण है, जिसका बड़ा लाभ यह है कि इसका उपयोग डेस्कटॉप और मोबाइल एप्लिकेशन दोनों के लिए किया जा सकता है। मूल रूप से यह एक्सटी जेएस (डेस्कटॉप एप्लिकेशन) और स्नेहा टच (मोबाइल एप्लिकेशन) का मर्ज है।
Ext JS एक जावास्क्रिप्ट ढांचा है, इसलिए इसका उपयोग शुरू करने के लिए आपको HTML और JS का पूर्व ज्ञान होना चाहिए (विशेषज्ञ स्तर नहीं, बल्कि बुनियादी समझ होनी चाहिए)। तब बुनियादी को समझने में समय लगता है इसलिए इसे समय दें और धीरे-धीरे सीखें।
दोनों चौखटे काफी अलग हैं हम Ext JS और jQuery UI की तुलना कर सकते हैं क्योंकि Ext JS पूरी तरह से UI रिच फ्रेमवर्क है। लेकिन फिर भी एक्सट जेएस में बहुत अधिक घटक हैं तो jQuery UI।
पैरामीटर | एक्सट जेएस | कोणीय जेएस |
---|---|---|
अमीर यूआई | Ext JS फॉर्मेट, ग्रिड, चार्ट जैसे समृद्ध UI विकल्प प्रदान करता है | कोणीय जेएस समृद्ध यूआई इनबिल्ट प्रदान नहीं करता है |
रिच थीम यूआई घटक | Ext JS इनबिल्ट कई थीम प्रदान करता है | Angular JS, Rich UI प्रदान नहीं करती है इसे AngularUI, AngularBootstarp आदि के साथ एकीकृत किया जाना है। |
क्रॉस ब्राउज़र संगतता | Ext JS, लगभग सभी ब्राउज़रों IE6 +, FF, Chrome, Safari, Opera आदि के लिए काम करने वाली क्रॉस ब्राउज़र संगतता प्रदान करता है। | कोणीय जेएस को इस उद्देश्य को हल करने के लिए jQuery, jqLite जैसे तीसरे पक्ष के पुस्तकालय का उपयोग करना है। |
स्वचालित परीक्षण समर्थन | केवल बाहरी उपकरणों के साथ संभव है | इनबिल्ट प्रदान करता है। |
दो तरह से डेटा बाइंडिंग | एक्सटी जेएस 5 में दो तरह से बाध्यकारी शामिल है। | यह पहले संस्करण से दो तरह से बाध्यकारी शुरुआत का समर्थन करता है। |
प्रदर्शन | एक्सटी जेएस तुलनात्मक रूप से भारी और धीमा है। | कोणीय JS, Ext JS की तुलना में हल्का वजन ढाँचा है |
उपकरण बनाएँ | Ext JS, बिल्ड के लिए Sencha cmd टूल का उपयोग करता है | एंगुलर जेएस ग्रंट जैसे थर्ड पार्टी टूल्स का उपयोग करता है। |
Ext JS 1.1
एक्सट जेएस का पहला संस्करण 2006 में जैक स्लोकम द्वारा विकसित किया गया था। यह उपयोगिता वर्गों का एक सेट था जो वाईयूआई का एक विस्तार है। उन्होंने पुस्तकालय का नाम YUI-ext रखा।
Ext JS 2.0
Ext JS संस्करण 2.0 2007 में जारी किया गया था। इस संस्करण में सीमित सुविधाओं के साथ डेस्कटॉप एप्लिकेशन के लिए नए एपीआई प्रलेखन थे। इस संस्करण में एक्सटी जेएस के पिछले संस्करण के साथ पिछड़े संगतता नहीं थी।
Ext JS 3.0
एक्सट जेएस संस्करण 3.0 को 2009 में जारी किया गया था। इस संस्करण में चार्ट और सूची दृश्य के रूप में लेकिन गति की कीमत पर नई सुविधाएँ जोड़ी गईं। यह संस्करण 2.0 के साथ पीछे की ओर संगत था।
Ext JS 4.0
एक्सट जेएस 3 की रिलीज के बाद एक्सट जेएस के डेवलपर्स को गति बढ़ाने की बड़ी चुनौती थी। एक्सट जेएस संस्करण 4.0 2011 में जारी किया गया था। इसमें पूर्ण संशोधित संरचना थी जो एमवीसी वास्तुकला और एक तेजी से अनुप्रयोग के बाद थी।
Ext JS 5.0
एक्सट जेएस संस्करण 5.0 2014 में जारी किया गया था। इस रिलीज में बड़ा बदलाव एमवीसी वास्तुकला को एमवीवीएम वास्तुकला में बदलना था। इसमें टच-सक्षम डिवाइस, दो-तरफ़ा डेटा बाइंडिंग, उत्तरदायी लेआउट और कई अन्य विशेषताओं पर डेस्कटॉप ऐप बनाने की क्षमता शामिल है।
Ext JS 6.0
एक्सट जेएस 6 एक्सट्रीम जेएस (डेस्कटॉप एप्लिकेशन के लिए) और स्नेहा टच (मोबाइल एप्लिकेशन के लिए) फ्रेमवर्क को मर्ज करता है।
एक्सट जेएस के विभिन्न यूआई घटक हैं जिनमें से कुछ प्रमुख घटक हैं -
- Grid
- Form
- संदेश पात्र
- प्रगति पट्टी
- टूल टिप
- Window
- HTML संपादक
- Charts
XType Ext JS UI घटक के प्रकार को परिभाषित करता है, जो घटक के प्रतिपादन के दौरान निर्धारित किया जाता है। जैसे टेक्स्ट टेक्स्ट, न्यूमेरिक, बटन आदि।
यह मान्यता प्रकार आसानी से अनुकूलित किया जा सकता है। एक्सटी जेएस द्वारा प्रदान किए गए कुछ vType हैं -
alphanumText - यदि टेक्स्ट में अल्फाबेट या न्यूमेरिक वैल्यू के अलावा कोई सिंबल है तो यह गलत है।
emailText - यह गलत है, अगर पाठ एक वैध ईमेल पता नहीं है।
हां एक्सट जेएस को अजाक्स के साथ एकीकृत किया जा सकता है। कार्यान्वयन के रूप में: कुछ पाठ बॉक्स पर मान लें कि धब्बा के बाद सर्वर से डेटा को मान्य करना है, इसके लिए हम टेक्स्ट बॉक्स आईडी में एक Ajax कॉल onblur / onchange हो सकता है यह जांचने के लिए कि क्या पाठ बॉक्स में दर्ज डेटा सर्वर या डेटाबेस में मौजूद है ।
यस एक्सट जेएस को अन्य सर्वर साइड फ्रेमवर्क जैसे कि जावा, .नेट, रूबी ऑन रेल्स, पीएचपी, कोल्डफ्यूजन आदि के साथ एकीकृत किया जा सकता है।
एक्सट जेएस को किसी भी लोकप्रिय एकीकृत विकास पर्यावरण (आईडीई) पर लागू किया जा सकता है, जैसे कि ग्रहण, अपटाना, उदात्त, वेबस्ट्रीम आदि।
एक्सटम JS में DOM तत्वों को एक्सेस करने के ये कुछ तरीके हैं -
- Ext.get()
- Ext.getElementById()
- Ext.fly()
- Ext.select()
MVVM आर्किटेक्चर मॉडल व्यू व्यूमॉडल है। MVVM में MVC के आर्किटेक्चर कंट्रोलर को ViewModel से बदल दिया गया है।
ViewModel- यह मूल रूप से दृश्य और मॉडल के बीच के परिवर्तनों की दवा है। यह मॉडल से डेटा को देखने के लिए बांधता है। एक ही समय में इसका कोई सीधा संवाद नहीं है, यह केवल मॉडल का ज्ञान है।
Ext.getCmp('buttonId').on('click', function(){
// statement to perform logic
});
Ext.onReady () पहला तरीका है जिसे कहा जाता है जब DOM पूरी तरह से लोड हो जाता है ताकि जो भी आप संदर्भित करना चाहते हैं वह स्क्रिप्ट के चलने पर उपलब्ध हो।
Ext.select('div').on('click', function(){
// statement to perform logic
});
Ext JS में विभिन्न प्रकार के अलर्ट बॉक्स हैं -
- Ext.MessageBox.alert();
- Ext.MessageBox.confirm();
- Ext.MessageBox.wait();
- Ext.MessageBox.promt();
- Ext.MessageBox.show();
स्टोर के लिए बेस कक्षाएं Ext.data.Store है
मॉडल के लिए Ext.data.Model है
नियंत्रक के लिए Ext.app.controller है
इवेंट हैंडलिंग के लिए ये अलग तरीके हैं -
- श्रोताओं का उपयोग करना
- घटनाओं को बाद में संलग्न करना
- कस्टम ईवेंट का उपयोग करना
Store.getCount() - कैश्ड रिकॉर्ड के लिए
Store.getTotalCount() - डीबी में कुल अभिलेखों की संख्या के लिए।
Store.getModifiedRecords () विधि का उपयोग संशोधित रिकॉर्ड प्राप्त करने के लिए किया जाता है।
Store.commitChanges () स्टोर परिवर्तन को अपडेट करने की विधि।
अगर हमारे पास ग्रिड आईडी है: Ext.getCmp ('gridId')। getStore ()। GetAt (index);
अगर हमारे पास Id है: Ext.getStore ('storeId')। getAt (index);
Store.load ();
- ग्रिड के लिए बेस क्लास - Ext.grid.GridPanel
- फॉर्म के लिए - Ext.form.Panel
- पैनल के लिए - Ext.panel.Panel
- चार्ट के लिए - Ext.chart.Chart
- पेड़ के लिए - Ext.tree.Panel
विभिन्न प्रकार के लेआउट हैं -
- Absolute
- Accordion
- Anchor
- Border
- Auto
- hBox
- vBox
- Card(TabPanel)
- Card(Wizard)
- Column
- Fit
- Table
यह पेजिंगटूलबार () का उपयोग करके किया जा सकता है -
new Ext.PagingToolbar ({
pageSize: 25,
store: store,
displayInfo: true,
displayMsg: 'Displaying topics {0} - {1} of {2}',
emptyMsg: 'No topics to display',
});
// trigger the data store load
store.load({params:{start:0, limit:25}});
dockedItems: [{
xtype: 'toolbar',
items: [{
id:'buttonId',
handler: function() {
Ext.Msg.alert('title','alertMsg');
});
}]
}]
लोडमास्क का उपयोग उपयोगकर्ता को लोड (या कस्टम संदेश) को दिखाने के लिए किया जाता है, जब तक कि डेटा ग्रिड को प्रदान नहीं किया जाता है। भारमास्क: सच; ग्रिड को प्रस्तुत किए जाने के दौरान लोडमैस्क दिखाने की संपत्ति है।
रेंडरर का उपयोग तब किया जाता है जब हम कुछ मानदंडों के आधार पर डेटा को हेरफेर करने के लिए स्टोर से प्राप्त करना चाहते हैं। यह एक स्तंभ संपत्ति के रूप में इस्तेमाल किया जा सकता है -
renderer: function(value, metadata, record, rowIndex, colIndex, store){
// logic to perform
}
। Ext.getCmp ( 'आईडी') getValue ();
छिपी: सच्ची;
क्रमबद्ध: सच; जो डिफ़ॉल्ट रूप से सत्य है।
grid.getStore().on ({
beforeload : function(store) {
// perform some operation
},
load : {
fn : function(store) {
//perform some operation
},
scope : this
}
store.load();
});
Ext JS 6 में टूलकिट पैकेज है जिसके साथ इसमें दोनों फ्रेमवर्क के दृश्य तत्व शामिल हो सकते हैं (एक्सटेंड जेएस और स्नेहा टच)।
इसे इस प्रकार जोड़ा जा सकता है -
'टूलकिट': 'क्लासिक', // या 'आधुनिक'
यदि टूलकिट क्लासिक है तो इसमें एक्सट जेएस डेस्कटॉप एप्लिकेशन फ्रेमवर्क शामिल है।
और अगर टूलकिट आधुनिक है, तो इसमें स्नेहा टच मोबाइल एप्लिकेशन फ्रेमवर्क शामिल है।
आगे क्या है?
इसके अलावा आप अपने पिछले असाइनमेंट के माध्यम से जा सकते हैं जो आपने विषय के साथ किया है और सुनिश्चित करें कि आप उन पर आत्मविश्वास से बात करने में सक्षम हैं। यदि आप नए हैं तो साक्षात्कारकर्ता को यह उम्मीद नहीं है कि आप बहुत जटिल प्रश्नों का उत्तर देंगे, बल्कि आपको अपनी मूल अवधारणाओं को बहुत मजबूत बनाना होगा।
दूसरा यह वास्तव में बहुत ज्यादा मायने नहीं रखता है अगर आप कुछ सवालों के जवाब नहीं दे सकते हैं लेकिन यह मायने रखता है कि आपने जो भी उत्तर दिया है, आपने आत्मविश्वास के साथ उत्तर दिया होगा। तो बस अपने साक्षात्कार के दौरान आत्मविश्वास महसूस करें। हम एक अच्छे साक्षात्कारकर्ता और आपके भविष्य के प्रयास के लिए बहुत बहुत शुभकामनाएँ। चियर्स :-)