सेंसहा टच - माइग्रेशन

सेन्चा टच पहले के संस्करण से विभिन्न सुधारों के साथ आता है।

स्नेहा टच 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 में हम सभी मॉडल, विचार, नियंत्रक और स्टोर को एप्लिकेशन में ही घोषित करते हैं।