स्नेहा टच - डिवाइस प्रोफाइल

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

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);
   }
});